ข้อจำกัดเกี่ยวกับการจัดเก็บและการดำเนินการข้อมูลใน Firebase Realtime Databaseมีดังนี้ หากต้องการขยายขนาดเกินขีดจำกัดเหล่านี้ ให้ใช้ฐานข้อมูลหลายรายการ
ทั่วโลก
การดำเนินการ | ขีดจำกัด | คำอธิบาย |
---|---|---|
การเชื่อมต่อพร้อมกัน | 200,000* | การเชื่อมต่อพร้อมกันเทียบเท่ากับอุปกรณ์เคลื่อนที่ แท็บเบราว์เซอร์ หรือแอปเซิร์ฟเวอร์ 1 รายการที่เชื่อมต่อกับฐานข้อมูล ซึ่งจะไม่เหมือนกับจำนวนผู้ใช้ทั้งหมดของแอป เนื่องจากผู้ใช้ไม่ได้เชื่อมต่อพร้อมกันทั้งหมด เช่น แอปที่มีผู้ใช้ที่ใช้งานอยู่รายเดือน 10 ล้านคนมักมีการเชื่อมต่อพร้อมกันน้อยกว่า 200,000 รายการ การเชื่อมต่อพร้อมกันสูงสุดจะขึ้นอยู่กับจำนวนผู้ใช้ทั้งหมดและเวลาเฉลี่ยที่ผู้ใช้ใช้ในแอป อย่างไรก็ตาม หากต้องการขยายขนาดเกินขีดจำกัดนี้ ให้ลองใช้ฐานข้อมูลหลายรายการ *แผน Spark มีขีดจำกัดการเชื่อมต่อพร้อมกันอยู่ที่ 100 รายการ |
การตอบกลับพร้อมกันที่ส่งจากฐานข้อมูลเดียว | ประมาณ 100,000/วินาที | คำตอบประกอบด้วยการออกอากาศและการอ่านพร้อมกันที่เซิร์ฟเวอร์ส่งจากฐานข้อมูลเดียวในเวลาที่กำหนด ขีดจำกัดหมายถึงแพ็กเก็ตข้อมูล ที่แสดงการอ่านหรือการออกอากาศแต่ละครั้ง ซึ่งรวมถึง การแจ้งเตือนแบบพุชที่ส่งจากฐานข้อมูล คำแนะนำนี้มีไว้สำหรับโหลดที่ต่อเนื่อง แต่ฐานข้อมูลสามารถรองรับการเพิ่มขึ้นที่สูงขึ้นเป็นครั้งคราวได้ |
จำนวน Cloud Functions ที่ทริกเกอร์โดยการเขียนครั้งเดียว | 1,000 หรือ 500 ต่อภูมิภาคสำหรับ Cloud Functions v2 | แม้ว่าจะไม่มีการจำกัดจำนวนการดำเนินการอ่านหรือเขียนที่คุณทริกเกอร์จากฟังก์ชันเดียว แต่การดำเนินการเขียนฐานข้อมูลเดียวจะทริกเกอร์ได้เพียง 1,000 ฟังก์ชัน หรือ 500 ฟังก์ชันต่อภูมิภาคสำหรับ Cloud Functions v2
Cloud Functions จะทริกเกอร์ได้เฉพาะการดำเนินการเขียน และแต่ละฟังก์ชันยังทริกเกอร์การดำเนินการเขียนเพิ่มเติมที่ทริกเกอร์ฟังก์ชันอื่นๆ ได้ด้วย (แต่ละฟังก์ชันมีขีดจำกัดของฟังก์ชัน 1, 000 รายการหรือ 500 รายการต่อภูมิภาค) |
ขนาดของเหตุการณ์เดียวที่ทริกเกอร์โดยการเขียน | 1 MB | ขนาดของเหตุการณ์ประกอบด้วยค่าต่อไปนี้
|
การโอนข้อมูลไปยัง Cloud Functions | 10 MB/วินาทีอย่างต่อเนื่อง | อัตราข้อมูลเหตุการณ์ที่ส่งต่อได้ไปยัง Cloud Functions |
โครงสร้างข้อมูล
พร็อพเพอร์ตี้ | ขีดจำกัด | คำอธิบาย |
---|---|---|
ความลึกสูงสุดของโหนดย่อย | 32 | แต่ละเส้นทางในแผนผังข้อมูลต้องมีความลึกไม่เกิน 32 ระดับ |
ความยาวของคีย์ | 768 ไบต์ | คีย์ได้รับการเข้ารหัส UTF-8 และต้องไม่มีบรรทัดใหม่หรืออักขระต่อไปนี้ $ # [ ] / หรืออักขระควบคุม ASCII (0x00 - 0x1F และ 0x7F) |
ขนาดสูงสุดของสตริง | 10 MB | ข้อมูลได้รับการเข้ารหัส UTF-8 |
การอ่าน
คำอธิบาย | ขีดจำกัด | หมายเหตุ |
---|---|---|
ขนาดของการตอบกลับเดียวที่ฐานข้อมูลแสดง | 256 MB | ข้อมูลที่ดาวน์โหลดจากฐานข้อมูลในตำแหน่งที่ตั้งเดียวควรมีขนาดน้อยกว่า 256 MB สำหรับการดำเนินการอ่านแต่ละครั้ง
หากต้องการดำเนินการอ่านในตำแหน่งที่ใหญ่ขึ้น ให้ลองใช้ตัวเลือกใดตัวเลือกหนึ่งต่อไปนี้ |
โหนดทั้งหมดในเส้นทางที่มี Listener หรือการค้นหา | 75 ล้าน* | คุณไม่สามารถฟังหรือค้นหาเส้นทางที่มีโหนดมากกว่า 75 ล้านโหนด
สะสม แต่คุณยังคงฟังหรือค้นหาโหนดลูกได้ ลองเจาะลึกเส้นทางหรือสร้างเครื่องมือฟังหรือคําค้นหาแยกต่างหากสําหรับส่วนที่เฉพาะเจาะจงมากขึ้นของเส้นทาง
*คุณดูเส้นทางที่มีโหนดทั้งหมดมากกว่า 30,000 รายการจากโปรแกรมแสดงข้อมูลในคอนโซล Firebase ไม่ได้ |
ระยะเวลาที่คำค้นหาเดียวจะทำงานได้ | 15 นาที* | การค้นหาเดียวจะทำงานได้นานสูงสุด 15 นาทีก่อนที่จะล้มเหลว
*การค้นหาเดียวที่ดำเนินการในคอนโซล Firebase จะทำงานได้ไม่เกิน 5 วินาทีก่อนที่จะล้มเหลว |
การเขียน
คำอธิบาย | ขีดจำกัด | หมายเหตุ |
---|---|---|
เขียนข้อมูลอัตรา | 1,000 การเขียน/วินาที | ขีดจำกัดของการดำเนินการเขียนต่อวินาทีในฐานข้อมูลเดียว แม้จะไม่ใช่ขีดจำกัดที่แน่นอน แต่หากคุณคงการเขียนมากกว่า 1,000 รายการต่อวินาที กิจกรรมการเขียนอาจถูกจำกัดอัตรา |
ขนาดของคำขอเขียนรายการเดียวไปยังฐานข้อมูล | 256 MB จาก REST API และ 16 MB จาก SDK | ข้อมูลทั้งหมดในการดำเนินการเขียนแต่ละครั้งควรมีขนาดน้อยกว่า 256 MB การอัปเดตแบบหลายเส้นทางจะขึ้นอยู่กับข้อจำกัดด้านขนาดเดียวกัน |
ไบต์ที่เขียนแล้ว | 64 MB/นาที | จำนวนไบต์ทั้งหมดที่เขียนผ่านการดำเนินการเขียนพร้อมกันใน ฐานข้อมูล ณ เวลาใดก็ตาม |