ต่อไปนี้คือข้อจำกัดเกี่ยวกับการจัดเก็บและการดำเนินการข้อมูลใน 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 ล้านโหนด
แบบสะสม แต่คุณยังคงฟังหรือค้นหาโหนดลูกได้ ลองเจาะลึกเส้นทางหรือสร้าง Listener หรือการค้นหาแยกต่างหากสำหรับส่วนที่เฉพาะเจาะจงมากขึ้นของเส้นทาง
*คุณดูเส้นทางที่มีโหนดทั้งหมดมากกว่า 30,000 รายการจากเครื่องมือแสดงข้อมูลในคอนโซล Firebase ไม่ได้ |
| ระยะเวลาที่การค้นหาเดียวจะทำงานได้ | 15 นาที* | การค้นหาเดียวจะทำงานได้นานสูงสุด 15 นาทีก่อนที่จะล้มเหลว
*การค้นหาครั้งเดียวที่ดำเนินการในคอนโซล Firebase จะทำงานได้ไม่เกิน 5 วินาทีก่อนที่จะล้มเหลว |
การเขียน
| คำอธิบาย | ขีดจำกัด | หมายเหตุ |
|---|---|---|
| เขียนข้อมูลอัตรา | 1,000 การเขียน/วินาที | ขีดจำกัดของการดำเนินการเขียนต่อวินาทีในฐานข้อมูลเดียว แม้จะไม่ใช่ขีดจำกัดที่แน่นอน แต่หากคุณคงการเขียนมากกว่า 1,000 รายการต่อวินาที กิจกรรมการเขียนอาจถูกจำกัดอัตรา |
| ขนาดของคำขอเขียนรายการเดียวไปยังฐานข้อมูล | 256 MB จาก REST API และ 16 MB จาก SDK | ข้อมูลทั้งหมดในการดำเนินการเขียนแต่ละครั้งควรมีขนาดน้อยกว่า 256 MB การอัปเดตแบบหลายเส้นทางจะขึ้นอยู่กับข้อจำกัดด้านขนาดเดียวกัน |
| ไบต์ที่เขียนแล้ว | 64 MB/นาที | จำนวนไบต์ทั้งหมดที่เขียนผ่านการดำเนินการเขียนพร้อมกันใน ฐานข้อมูล ณ เวลาใดก็ตาม |