คุณสามารถใช้ทั้ง Firebase Realtime Database และ Cloud Firestore ในแอปได้ และใช้ประโยชน์จากข้อดีของโซลูชันฐานข้อมูลแต่ละรายการให้เหมาะกับความต้องการของคุณ เช่น คุณอาจต้องการใช้ประโยชน์จากการรองรับการแสดงข้อมูลของ Realtime Database ตามที่ระบุไว้ในสร้างการแสดงข้อมูลใน Cloud Firestore
ดูข้อมูลเพิ่มเติมเกี่ยวกับความแตกต่างระหว่างฐานข้อมูล
กำลังย้ายข้อมูลไปที่ Cloud Firestore
หากตัดสินใจว่าต้องการย้ายข้อมูลบางส่วนจาก Realtime Database ไปยัง Cloud Firestore ให้พิจารณาขั้นตอนต่อไปนี้ เนื่องจากฐานข้อมูลทั้งหมดมีความต้องการและการพิจารณาด้านโครงสร้างที่แตกต่างกัน จึงไม่มีเส้นทางการย้ายข้อมูลแบบอัตโนมัติ แต่ให้ทำตามขั้นตอนทั่วไปต่อไปนี้แทน
แมปโครงสร้างข้อมูลและกฎความปลอดภัยจาก Realtime Database ถึง Cloud Firestore ทั้ง Realtime Database และ Cloud Firestore ต่างก็ใช้ Firebase Authentication คุณจึงไม่ต้องเปลี่ยนการตรวจสอบสิทธิ์ผู้ใช้สําหรับแอป อย่างไรก็ตาม กฎด้านความปลอดภัยและรูปแบบข้อมูลจะแตกต่างกัน คุณจึงต้องพิจารณาความแตกต่างเหล่านี้อย่างรอบคอบก่อนที่จะเริ่มย้ายข้อมูลไปยัง Cloud Firestore
ย้ายข้อมูลย้อนหลัง ขณะตั้งค่าโครงสร้างข้อมูลใหม่ใน Cloud Firestore คุณสามารถแมปและย้ายข้อมูลจาก Realtime Database ไปยังอินสแตนซ์ Cloud Firestore ใหม่ได้ อย่างไรก็ตาม หากคุณใช้ทั้ง 2 ฐานข้อมูลในแอป คุณไม่จำเป็นต้องย้ายข้อมูลย้อนหลังออกจาก Realtime Database
มิเรอร์ข้อมูลใหม่ไปยัง Firestore แบบเรียลไทม์ ใช้ Cloud Functions เพื่อเขียนข้อมูลใหม่ลงในCloud Firestoreฐานข้อมูลRealtime Databaseใหม่เมื่อมีการเพิ่มลงใน Realtime Database
ทําให้ Cloud Firestore เป็นฐานข้อมูลหลักสําหรับข้อมูลที่ย้ายมา เมื่อย้ายข้อมูลบางส่วนแล้ว ให้ใช้ Cloud Firestore เป็นฐานข้อมูลหลักและลดการใช้ Realtime Database สำหรับข้อมูลที่ย้ายข้อมูล พิจารณาเวอร์ชันของแอปที่ยังคงเชื่อมโยงกับ Realtime Database สำหรับข้อมูลดังกล่าว และวิธีที่คุณวางแผนจะรองรับเวอร์ชันเหล่านั้นต่อไป
อย่าลืมพิจารณาค่าใช้จ่ายในการเรียกเก็บเงินสำหรับทั้ง Realtime Database และ Cloud Firestore
แมปข้อมูล
ข้อมูลใน Realtime Database มีโครงสร้างเป็นต้นไม้เดี่ยว ส่วน Cloud Firestore รองรับลําดับชั้นข้อมูลที่ชัดเจนมากขึ้นผ่านเอกสาร คอลเล็กชัน และกลุ่มย่อย หากย้ายข้อมูลบางส่วนจาก Realtime Database ไปยัง Cloud Firestore คุณอาจต้องพิจารณาใช้สถาปัตยกรรมอื่นสำหรับข้อมูล
ความแตกต่างสำคัญที่ต้องพิจารณา
หากคุณย้ายข้อมูลจากต้นไม้ Realtime Database ที่มีอยู่ไปยังเอกสารและคอลเล็กชัน โปรดทราบว่าฐานข้อมูลมีความแตกต่างที่สำคัญต่อไปนี้ซึ่งอาจส่งผลต่อวิธีจัดโครงสร้างข้อมูลใน Cloud FirestoreCloud Firestore
- การค้นหาแบบตื้นมีความยืดหยุ่นมากขึ้นในโครงสร้างข้อมูลที่จัดลำดับชั้น
- การค้นหาที่ซับซ้อนจะมีความละเอียดมากขึ้นและลดความจำเป็นในการใช้ข้อมูลที่ซ้ำกัน
- เคอร์เซอร์การค้นหาจะระบุเลขหน้าให้มีประสิทธิภาพมากขึ้น
- ธุรกรรมไม่จำเป็นต้องมีรูทร่วมกันสำหรับข้อมูลทั้งหมดอีกต่อไป แต่มีประสิทธิภาพมากกว่า
- ค่าบริการเรียกเก็บเงินจะแตกต่างกันระหว่าง Realtime Database ถึง Cloud Firestore ในหลายๆ กรณี Cloud Firestore อาจแพงกว่า Realtime Database โดยเฉพาะอย่างยิ่งหากคุณใช้การดำเนินการขนาดเล็กจำนวนมาก ลองพิจารณาลดจำนวนการดำเนินการในฐานข้อมูลและหลีกเลี่ยงการเขียนที่ไม่จำเป็น ดูข้อมูลเพิ่มเติมเกี่ยวกับความแตกต่างของการเรียกเก็บเงินระหว่าง Realtime Database กับ Cloud Firestore
แนวทางปฏิบัติแนะนำที่ใช้งานได้จริง
ตัวอย่างต่อไปนี้แสดงถึงสิ่งที่คุณควรพิจารณาเมื่อย้ายข้อมูลระหว่างฐานข้อมูล คุณใช้ประโยชน์จากการอ่านแบบตื้นและความสามารถในการค้นหาที่ปรับปรุงแล้วเพื่อโครงสร้างข้อมูลที่เป็นธรรมชาติมากกว่าที่เคยใช้กับ Realtime Database ได้
ลองพิจารณาแอปคู่มือเมืองที่ช่วยให้ผู้ใช้ค้นหาจุดสังเกตที่น่าสนใจในเมืองต่างๆ ทั่วโลก เนื่องจาก Realtime Database ไม่มีการอ่านแบบออบเจ็กต์ คุณจึงอาจต้องจัดโครงสร้างข้อมูลในโหนดระดับบนสุด 2 รายการ ดังนี้
// /cities/$CITY_KEY
{
name: "New York",
population: 8000000,
capital: False
}
// /city-landmark/$CITY_KEY/$LANDMARK_KEY
{
name: "Empire State Building",
category: "Architecture"
}
Cloud Firestore มีการอ่านแบบตื้น ดังนั้นการค้นหาเอกสารในคอลเล็กชันจะไม่ดึงข้อมูลจากคอลเล็กชันย่อย คุณจึงจัดเก็บข้อมูลจุดสังเกตในคอลเล็กชันย่อยได้ ดังนี้
// /cities/$CITY_ID
{
name: "New York",
population: 8000000,
capital: False,
landmarks: [... subcollection ...]
}
เอกสารต้องมีขนาดไม่เกิน 1 MB ซึ่งเป็นอีกเหตุผลหนึ่งที่จะต้องจัดเก็บจุดสังเกตเป็นคอลเล็กชันย่อย ทำให้เอกสารแต่ละฉบับของเมืองมีขนาดเล็ก แทนที่จะทำให้เอกสารที่มีรายการที่ซ้อนกันอยู่เป็นจำนวนมาก
ความสามารถในการค้นหาขั้นสูงของ Cloud Firestore ช่วยลดความจำเป็นในการทำซ้ำข้อมูลสำหรับรูปแบบการเข้าถึงทั่วไป ตัวอย่างเช่น พิจารณาหน้าจอในแอปคู่มือเมืองที่แสดงเมืองหลวงทั้งหมดเรียงตามจำนวนประชากร
ใน Realtime Database วิธีที่มีประสิทธิภาพมากที่สุดคือการดูแลรายการเมืองหลวงแยกต่างหากซึ่งทำซ้ำข้อมูลจากรายการ cities
ดังนี้
{
cities: {
// ...
},
capital-cities: {
// ...
}
}
ใน Cloud Firestore คุณสามารถแสดงรายการเมืองหลวงตามลำดับจำนวนประชากรเป็นคําค้นหาเดียวได้ ดังนี้
db.collection('cities')
.where('capital', '==', true)
.orderBy('population')
อ่านเพิ่มเติมเกี่ยวกับCloud Firestoreโมเดลข้อมูลและดูโซลูชันของเราเพื่อดูแนวคิดเพิ่มเติมเกี่ยวกับวิธีจัดโครงสร้างCloud Firestoreฐานข้อมูล
รักษาข้อมูลของคุณให้ปลอดภัย
ไม่ว่าคุณจะใช้ Cloud Firestore Security Rules สำหรับไคลเอ็นต์ Android, Apple หรือเว็บ หรือการจัดการสิทธิ์เข้าถึงข้อมูลประจำตัว (IAM) สำหรับเซิร์ฟเวอร์ โปรดตรวจสอบว่าคุณได้รักษาความปลอดภัยให้กับข้อมูลใน Cloud Firestore และ Realtime Database ด้วย การตรวจสอบสิทธิ์ผู้ใช้ได้รับการจัดการโดยการตรวจสอบสิทธิ์สำหรับฐานข้อมูลทั้ง 2 รายการ คุณจึงไม่จำเป็นต้องเปลี่ยนการใช้งานการตรวจสอบสิทธิ์เมื่อเริ่มใช้ Cloud Firestore
ความแตกต่างที่สำคัญที่ควรพิจารณา
- SDK บนอุปกรณ์เคลื่อนที่และเว็บใช้ Cloud Firestore Security Rules ส่วน SDK ของเซิร์ฟเวอร์ใช้ Identity Access Management (IAM) เพื่อรักษาความปลอดภัยของข้อมูล
- Cloud Firestore Security Rules จะไม่ทํางานแบบ Cascade เว้นแต่คุณจะใช้ไวลด์การ์ด เอกสารและคอลเล็กชันจะไม่รับค่ากฎจากส่วนกลาง
- คุณไม่จําเป็นต้องตรวจสอบข้อมูลแยกต่างหากอีกต่อไป (เหมือนที่เคยทําใน Realtime Database)
- Cloud Firestore จะตรวจสอบกฎก่อนดำเนินการค้นหาเพื่อให้แน่ใจว่าผู้ใช้มีสิทธิ์เข้าถึงที่เหมาะสมสำหรับข้อมูลทั้งหมดที่การค้นหาแสดง
ย้ายข้อมูลย้อนหลังไปยัง Cloud Firestore
เมื่อแมปโครงสร้างข้อมูลและโครงสร้างการรักษาความปลอดภัยกับโมเดลข้อมูลและการรักษาความปลอดภัยของ Cloud Firestore แล้ว คุณจะเริ่มต้นเพิ่มข้อมูลได้ หากคุณวางแผนที่จะค้นหาข้อมูลย้อนหลังจากย้ายแอปจาก Realtime Database ไปCloud Firestore ให้เพิ่มการส่งออกข้อมูลเก่าไปยังฐานข้อมูล Cloud Firestore ใหม่ หากวางแผนที่จะใช้ทั้ง Realtime Database และ Cloud Firestore ในแอป ให้ข้ามขั้นตอนนี้
คุณอาจต้องเพิ่มข้อมูลย้อนหลังก่อนเพื่อหลีกเลี่ยงการเขียนทับข้อมูลใหม่ด้วยข้อมูลเก่า หากคุณเพิ่มข้อมูลใหม่ลงในทั้ง 2 ฐานข้อมูลพร้อมกัน ตามที่อธิบายไว้ในขั้นตอนถัดไป โปรดให้ความสําคัญกับข้อมูลที่เพิ่มลงในCloud Firestoreโดย Cloud Functions
หากต้องการย้ายข้อมูลประวัติไปยัง Cloud Firestore ให้ทำตามขั้นตอนต่อไปนี้
- ส่งออกข้อมูลจาก Realtime Database หรือใช้ข้อมูลสํารองล่าสุด
- ไปที่ส่วน Realtime Database ในคอนโซล Firebase
- จากแท็บข้อมูล ให้เลือกโหนดระดับรูทของฐานข้อมูล แล้วเลือกส่งออก JSON จากเมนู
สร้างฐานข้อมูลใหม่ใน Cloud Firestore และเพิ่มข้อมูล
พิจารณากลยุทธ์ต่อไปนี้เมื่อย้ายข้อมูลบางส่วนไปยัง Cloud Firestore
- เขียนสคริปต์ที่กำหนดเองซึ่งพอร์ตข้อมูลให้คุณ แม้ว่าเราจะเสนอเทมเพลตสคริปต์นี้ไม่ได้เนื่องจากฐานข้อมูลแต่ละแห่งจะมีความต้องการที่ไม่เหมือนกัน แต่Cloud Firestoreผู้เชี่ยวชาญในแชแนล Slack หรือใน Stack Overflow สามารถตรวจสอบสคริปต์หรือให้คําแนะนําสําหรับสถานการณ์เฉพาะของคุณได้
- ใช้ SDK ของเซิร์ฟเวอร์ (Node.js, Java, Python หรือ Go) เพื่อเขียนข้อมูลลงใน Cloud Firestore โดยตรง ดูวิธีการตั้งค่า SDK ของเซิร์ฟเวอร์ได้ที่เริ่มต้นใช้งาน
- หากต้องการย้ายข้อมูลจำนวนมากให้รวดเร็วขึ้น ให้ใช้การเขียนแบบเป็นกลุ่มและส่งการดำเนินการได้สูงสุด 500 รายการในคำขอเครือข่ายเดียว
- หากต้องการไม่ให้มีการดำเนินการเกินCloud Firestore Rate Limit ให้จำกัดการดำเนินการเขียนไว้ที่ 500 รายการต่อวินาทีสำหรับแต่ละคอลเล็กชัน
เพิ่มข้อมูลใหม่ลงใน Cloud Firestore
โปรดเพิ่มข้อมูลใหม่ลงในฐานข้อมูลทั้ง 2 แบบแบบเรียลไทม์เพื่อรักษาความสอดคล้องระหว่างฐานข้อมูล ใช้ Cloud Functions เพื่อทริกเกอร์การเขียนไปยัง Cloud Firestore เมื่อใดก็ตามที่ไคลเอ็นต์เขียนไปยัง Realtime Database ตรวจสอบว่า Cloud Firestore ให้ความสำคัญกับข้อมูลใหม่ที่มาจาก Cloud Functions เหนือกว่าการเขียนจากการย้ายข้อมูลประวัติ
สร้างฟังก์ชันเพื่อเขียนข้อมูลใหม่หรือข้อมูลที่เปลี่ยนแปลงลงใน Cloud Firestore ทุกครั้งที่ไคลเอ็นต์เขียนข้อมูลลงใน Realtime Database ดูข้อมูลเพิ่มเติมเกี่ยวกับทริกเกอร์ Realtime Database สำหรับ Cloud Functions
กำหนดให้ Cloud Firestore เป็นฐานข้อมูลหลักสำหรับข้อมูลที่ย้ายมา
หากตัดสินใจที่จะใช้ Cloud Firestore เป็นฐานข้อมูลหลักสําหรับข้อมูลบางอย่าง โปรดตรวจสอบว่าคุณได้พิจารณาฟังก์ชันการมิเรอร์ข้อมูลที่คุณตั้งค่าไว้และตรวจสอบ Cloud Firestore Security Rules
หากคุณใช้ Cloud Functions เพื่อรักษาความสอดคล้องระหว่างฐานข้อมูล ให้ตรวจสอบว่าคุณไม่ได้ทำการดำเนินการเขียนซ้ำในทั้ง 2 ฐานข้อมูลในลูป เปลี่ยนฟังก์ชันให้เขียนลงในฐานข้อมูลเดียวหรือนำฟังก์ชันออกโดยสมบูรณ์และเริ่มยกเลิกฟังก์ชันการเขียนสำหรับข้อมูลที่ย้ายในแอปที่ยังคงเชื่อมโยงกับ Realtime Database วิธีจัดการเรื่องนี้สําหรับแอปจะขึ้นอยู่กับความต้องการเฉพาะและผู้ใช้ของคุณ
ตรวจสอบว่าข้อมูลได้รับการรักษาความปลอดภัยอย่างเหมาะสม ตรวจสอบการตั้งค่า Cloud Firestore Security Rules หรือ IAM