پرس و جوهای بلادرنگ را در مقیاس درک کنید

این سند را برای راهنمایی در مورد مقیاس گذاری برنامه بدون سرور خود فراتر از هزاران عملیات در ثانیه یا صدها هزار کاربر همزمان بخوانید. این سند شامل موضوعات پیشرفته برای کمک به درک عمیق سیستم است. اگر تازه کار را با Cloud Firestore شروع کرده اید، به جای آن به راهنمای شروع سریع مراجعه کنید.

Cloud Firestore و SDKهای موبایل/وب Firebase یک مدل قدرتمند برای توسعه برنامه‌های بدون سرور ارائه می‌کنند که در آن کد سمت کلاینت مستقیماً به پایگاه داده دسترسی پیدا می‌کند. SDKها به مشتریان اجازه می‌دهند به‌روزرسانی‌های داده‌ها را در زمان واقعی گوش دهند. می‌توانید از به‌روزرسانی‌های بی‌درنگ برای ساخت برنامه‌های واکنش‌گرا که به زیرساخت سرور نیاز ندارند، استفاده کنید. اگرچه راه‌اندازی و اجرا کردن چیزی بسیار آسان است، اما به درک محدودیت‌های موجود در سیستم‌هایی که Cloud Firestore را تشکیل می‌دهند کمک می‌کند تا برنامه بدون سرور شما در زمان افزایش ترافیک، مقیاس‌پذیر شود و عملکرد خوبی داشته باشد.

برای مشاوره در مورد افزایش مقیاس برنامه خود به بخش های زیر مراجعه کنید.

یک مکان پایگاه داده نزدیک به کاربران خود انتخاب کنید

نمودار زیر معماری یک اپلیکیشن بلادرنگ را نشان می دهد:

نمونه ای از معماری اپلیکیشن بلادرنگ

وقتی برنامه‌ای که در دستگاه کاربر اجرا می‌شود (موبایل یا وب) با Cloud Firestore ارتباط برقرار می‌کند، اتصال به سرور فرانت‌اند Cloud Firestore در همان منطقه‌ای که پایگاه داده شما در آن قرار دارد هدایت می‌شود. به عنوان مثال، اگر پایگاه داده شما در us-east1 باشد، اتصال به یک فرانت اند Cloud Firestore نیز در us-east1 می رود. این اتصالات عمر طولانی دارند و تا زمانی که برنامه به صراحت بسته نشود باز می مانند. قسمت جلویی داده ها را از سیستم های ذخیره سازی Cloud Firestore زیرین می خواند.

فاصله بین مکان فیزیکی کاربر و مکان پایگاه داده Cloud Firestore بر تأخیر تجربه شده توسط کاربر تأثیر می گذارد. برای مثال، کاربری در هند که برنامه‌اش با پایگاه داده‌ای در یک منطقه Google Cloud در آمریکای شمالی صحبت می‌کند، ممکن است تجربه کندتر و نرم‌افزار کمتری نسبت به زمانی که پایگاه داده نزدیک‌تر باشد، مثلاً در هند یا در بخشی دیگر از آسیا، تجربه کندتر و نرم‌افزار کمتری پیدا کند. .

طراحی برای قابلیت اطمینان

موضوعات زیر قابلیت اطمینان برنامه شما را بهبود می بخشد یا بر آن تأثیر می گذارد:

حالت آفلاین را فعال کنید

SDK های Firebase پایداری داده های آفلاین را ارائه می دهند. اگر برنامه موجود در دستگاه کاربر نتواند به Cloud Firestore متصل شود، برنامه با کار با داده‌های ذخیره‌شده محلی قابل استفاده باقی می‌ماند. این امر دسترسی به داده‌ها را تضمین می‌کند حتی زمانی که کاربران اتصالات اینترنتی ناقص را تجربه می‌کنند یا برای چندین ساعت یا چند روز به طور کامل دسترسی را از دست می‌دهند. برای جزئیات بیشتر در مورد حالت آفلاین، به فعال کردن داده آفلاین مراجعه کنید.

تلاش های مجدد خودکار را درک کنید

Firebase SDK از تلاش مجدد عملیات و برقراری مجدد اتصالات شکسته مراقبت می کند. این به رفع خطاهای گذرا ناشی از راه اندازی مجدد سرورها یا مشکلات شبکه بین مشتری و پایگاه داده کمک می کند.

بین مکان های منطقه ای و چند منطقه ای انتخاب کنید

هنگام انتخاب بین مکان های منطقه ای و چند منطقه ای چندین مبادله وجود دارد. تفاوت اصلی این است که چگونه داده ها تکرار می شوند. این باعث تضمین در دسترس بودن برنامه شما می شود. یک نمونه چند منطقه ای قابلیت اطمینان سرویس دهی قوی تری می دهد و ماندگاری داده های شما را افزایش می دهد، اما مبادله آن هزینه است.

سیستم پرس و جو بلادرنگ را درک کنید

پرس و جوهای بلادرنگ که شنونده عکس فوری نیز نامیده می شوند، به برنامه اجازه می دهند به تغییرات پایگاه داده گوش دهد و به محض تغییر داده ها اعلان هایی با تاخیر کم دریافت کند. یک برنامه می‌تواند با نظرسنجی دوره‌ای پایگاه داده برای به‌روزرسانی‌ها، همان نتیجه را بگیرد، اما اغلب کندتر، گران‌تر است و به کد بیشتری نیاز دارد. برای مثال‌هایی از نحوه راه‌اندازی و استفاده از جستارهای هم‌زمان، به دریافت به‌روزرسانی‌های هم‌زمان مراجعه کنید. بخش‌های زیر به جزئیات نحوه عملکرد شنوندگان عکس فوری می‌پردازند و برخی از بهترین روش‌ها را برای مقیاس‌بندی پرسش‌های بلادرنگ با حفظ عملکرد توصیف می‌کنند.

دو کاربر را تصور کنید که از طریق یک برنامه پیام رسانی ساخته شده با یکی از SDK های تلفن همراه به Cloud Firestore متصل می شوند.

کلاینت A برای افزودن و به روز رسانی اسناد در مجموعه ای به نام chatroom به پایگاه داده می نویسد:

collection chatroom:
    document message1:
      from: 'Sparky'
      message: 'Welcome to Cloud Firestore!'

    document message2:
      from: 'Santa'
      message: 'Presents are coming'

کلاینت B با استفاده از شنونده عکس فوری به به‌روزرسانی‌ها در همان مجموعه گوش می‌دهد. هر زمان که شخصی پیام جدیدی ایجاد کند، کلاینت B یک اعلان فوری دریافت می کند. نمودار زیر معماری پشت یک شنونده عکس فوری را نشان می دهد:

معماری اتصال شنونده عکس فوری

زمانی که Client B یک شنونده عکس فوری را به پایگاه داده متصل می کند، توالی رویدادهای زیر رخ می دهد:

  1. Client B یک اتصال به Cloud Firestore باز می کند و یک شنونده را با برقراری تماس با onSnapshot(collection("chatroom")) از طریق Firebase SDK ثبت می کند. این شنونده می تواند ساعت ها فعال بماند.
  2. فرانت‌اند Cloud Firestore از سیستم ذخیره‌سازی زیربنایی پرس و جو می‌کند تا مجموعه داده را بوت استرپ کند. کل مجموعه نتیجه اسناد تطبیق را بارگیری می کند. ما به این به عنوان یک پرسش نظرسنجی اشاره می کنیم. سپس سیستم قوانین امنیتی Firebase پایگاه داده را ارزیابی می کند تا تأیید کند که کاربر می تواند به این داده ها دسترسی داشته باشد. اگر کاربر مجاز باشد، پایگاه داده داده ها را به کاربر برمی گرداند.
  3. پرس و جو مشتری B سپس به حالت گوش دادن منتقل می شود. شنونده با یک کنترل کننده اشتراک ثبت نام می کند و منتظر به روز رسانی داده ها است.
  4. کلاینت A اکنون یک عملیات نوشتن برای تغییر یک سند ارسال می کند.
  5. پایگاه داده تغییر سند را به سیستم ذخیره سازی خود انجام می دهد.
  6. از نظر معاملاتی، سیستم همان به‌روزرسانی را به یک تغییرات داخلی متعهد می‌کند. تغییرات ثبت یک ترتیب دقیق از تغییرات به عنوان آنها ایجاد می کند.
  7. تغییرات به نوبه خود داده های به روز شده را به مجموعه ای از کنترل کننده های اشتراک ارسال می کند.
  8. یک تطبیق پرس و جو معکوس اجرا می شود تا ببیند آیا سند به روز شده با هر شنونده عکس فوری ثبت شده فعلی مطابقت دارد یا خیر. در این مثال، سند با شنونده عکس فوری Client B مطابقت دارد. همانطور که از نام آن پیداست، می توانید تطبیق پرس و جو معکوس را به عنوان یک پرس و جو پایگاه داده معمولی در نظر بگیرید اما به صورت معکوس انجام می شود. به جای جستجو در اسناد برای یافتن مواردی که با یک پرس و جو مطابقت دارند، به طور موثر در جستجوها جستجو می کند تا مواردی را که با یک سند ورودی مطابقت دارند را بیابد. پس از یافتن یک مطابقت، سیستم سند مورد نظر را به شنوندگان عکس فوری ارسال می کند. سپس سیستم قوانین امنیتی Firebase پایگاه داده را ارزیابی می کند تا مطمئن شود که فقط کاربران مجاز داده ها را دریافت می کنند.
  9. سیستم به روز رسانی سند را به SDK در دستگاه مشتری B ارسال می کند و پاسخ به تماس onSnapshot فعال می شود. اگر تداوم محلی فعال باشد، SDK به‌روزرسانی را در حافظه پنهان محلی نیز اعمال می‌کند.

بخش مهمی از مقیاس پذیری Cloud Firestore به خروج از تغییرات به کنترل کننده های اشتراک و سرورهای فرانت اند بستگی دارد. فن خروجی به یک داده اجازه می دهد تا به طور موثر منتشر شود تا به میلیون ها پرس و جوی بلادرنگ و کاربران متصل ارائه شود. Cloud Firestore با اجرای کپی‌های بسیاری از همه این مؤلفه‌ها در چندین منطقه (یا چندین منطقه در مورد استقرار چند منطقه‌ای)، به دسترسی و مقیاس‌پذیری بالایی دست می‌یابد.

شایان ذکر است که تمام عملیات خواندن صادر شده از SDK های موبایل و وب از مدل بالا پیروی می کنند. آنها یک پرس و جوی نظرسنجی و به دنبال آن حالت گوش دادن برای حفظ ضمانت های سازگاری انجام می دهند. این همچنین برای شنوندگان بلادرنگ، تماس‌هایی که برای بازیابی یک سند و پرس‌وجوهای تک‌شات انجام می‌شود، صدق می‌کند. می‌توانید بازیابی‌های سند تکی و درخواست‌های تک‌شات را به‌عنوان شنوندگان عکس فوری کوتاه‌مدت در نظر بگیرید که با محدودیت‌های مشابهی در مورد عملکرد همراه هستند.

بهترین شیوه ها را برای مقیاس بندی پرس و جوهای بلادرنگ اعمال کنید

بهترین روش‌های زیر را برای طراحی پرسش‌های بلادرنگ مقیاس‌پذیر اعمال کنید.

ترافیک نوشتن بالا در سیستم را درک کنید

این بخش به شما کمک می کند تا بفهمید سیستم چگونه به تعداد فزاینده ای از درخواست های نوشتن پاسخ می دهد.

تغییرات Cloud Firestore که پرس و جوهای بلادرنگ را به طور خودکار به صورت افقی با افزایش ترافیک نوشتن هدایت می کند. از آنجایی که نرخ نوشتن برای یک پایگاه داده فراتر از آن چیزی است که یک سرور می تواند مدیریت کند، تغییرات ثبت شده در چندین سرور تقسیم می شود و پردازش پرس و جو شروع به مصرف داده ها از چندین کنترل کننده اشتراک به جای یک می کند. از دیدگاه کلاینت و SDK، همه اینها شفاف است و در صورت وقوع انشعاب، هیچ اقدامی از برنامه لازم نیست. نمودار زیر چگونگی مقیاس پرس و جوهای بلادرنگ را نشان می دهد:

معماری فن خروجی تغییرات

مقیاس‌بندی خودکار به شما امکان می‌دهد ترافیک نوشتن خود را بدون محدودیت افزایش دهید، اما با افزایش ترافیک، پاسخ سیستم ممکن است کمی طول بکشد. توصیه های قانون 5-5-5 را دنبال کنید تا از ایجاد نقطه اتصال نوشتن اجتناب کنید. Key Visualizer یک ابزار مفید برای تجزیه و تحلیل نقاط مهم نوشتن است.

بسیاری از برنامه‌ها دارای رشد ارگانیک قابل پیش‌بینی هستند که Cloud Firestore می‌تواند بدون احتیاط از آن استفاده کند. با این حال، بارهای کاری دسته‌ای مانند وارد کردن یک مجموعه داده بزرگ، می‌تواند نوشتن را خیلی سریع افزایش دهد. همانطور که برنامه خود را طراحی می کنید، از اینکه ترافیک نوشتن شما از کجا می آید آگاه باشید.

نحوه تعامل نوشتن و خواندن را درک کنید

شما می توانید سیستم پرس و جوی بلادرنگ را به عنوان خط لوله ای که عملیات نوشتن را با خواننده ها متصل می کند، در نظر بگیرید. هر زمان که سندی ایجاد، به‌روزرسانی یا حذف می‌شود، این تغییر از سیستم ذخیره‌سازی به شنوندگان ثبت‌شده فعلی منتشر می‌شود. ساختار تغییرات Cloud Firestore یکپارچگی قوی را تضمین می‌کند، به این معنی که برنامه شما هرگز اعلان‌های به‌روزرسانی‌هایی را دریافت نمی‌کند که در مقایسه با زمانی که پایگاه داده تغییرات داده‌ها را انجام می‌دهد، نامرتب هستند. این امر توسعه برنامه را با حذف موارد لبه حول ثبات داده ها ساده می کند.

این خط لوله متصل به این معنی است که یک عملیات نوشتن که باعث ایجاد هات اسپات یا اختلاف قفل می شود می تواند بر عملیات خواندن تأثیر منفی بگذارد. هنگامی که عملیات نوشتن با شکست مواجه می‌شود یا کاهش می‌یابد، ممکن است خواندن در انتظار داده‌های ثابت از تغییرات ثبت شود. اگر این اتفاق در برنامه شما بیفتد، ممکن است هم عملیات نوشتن کند و هم زمان پاسخ آهسته مرتبط برای پرس و جوها را ببینید. اجتناب از نقاط مهم کلیدی برای فرار از این مشکل است.

اسناد را کوچک نگه دارید و عملیات بنویسید

هنگام ساختن برنامه‌ها با شنونده‌های عکس فوری، معمولاً می‌خواهید کاربران به سرعت از تغییرات داده‌ها مطلع شوند. برای رسیدن به این هدف، سعی کنید چیزها را کوچک نگه دارید. این سیستم می تواند اسناد کوچک با ده ها فیلد را خیلی سریع از طریق سیستم عبور دهد. پردازش اسناد بزرگتر با صدها فیلد و داده های بزرگ به زمان بیشتری نیاز دارد.

به همین ترتیب، از انجام عملیات کوتاه و سریع و نوشتن برای پایین نگه داشتن تاخیر استفاده کنید. دسته های بزرگ ممکن است از دیدگاه نویسنده به شما توان عملیاتی بالاتری بدهد، اما در واقع ممکن است زمان اعلان را برای شنوندگان عکس فوری افزایش دهد. این اغلب در مقایسه با استفاده از سایر سیستم های پایگاه داده که در آن شما ممکن است از دسته بندی برای بهبود عملکرد استفاده کنید، غیر منطقی است.

از شنوندگان کارآمد استفاده کنید

با افزایش نرخ نوشتن برای پایگاه داده شما، Cloud Firestore پردازش داده ها را در بسیاری از سرورها تقسیم می کند. الگوریتم اشتراک گذاری Cloud Firestore تلاش می کند تا داده ها را از همان مجموعه یا گروه مجموعه در همان سرور تغییرات ایجاد کند. این سیستم سعی می‌کند تا سرعت نوشتن ممکن را به حداکثر برساند و در عین حال تعداد سرورهای درگیر در پردازش یک پرس و جو را تا حد ممکن کم نگه دارد.

با این حال، برخی از الگوها ممکن است همچنان منجر به رفتار غیربهینه برای شنوندگان عکس فوری شود. به عنوان مثال، اگر برنامه شما بیشتر داده های خود را در یک مجموعه بزرگ ذخیره می کند، شنونده ممکن است برای دریافت تمام داده های مورد نیاز خود به سرورهای زیادی متصل شود. حتی اگر فیلتر پرس و جو را اعمال کنید، این موضوع صادق است. اتصال به بسیاری از سرورها خطر پاسخ های کندتر را افزایش می دهد.

برای جلوگیری از این پاسخ های کندتر، طرح و برنامه خود را طوری طراحی کنید که سیستم بتواند بدون مراجعه به سرورهای مختلف به شنوندگان خدمات ارائه دهد. ممکن است بهترین کار این باشد که داده های خود را به مجموعه های کوچکتر با نرخ نوشتن کمتر تقسیم کنید.

این شبیه به تفکر در مورد پرس و جوهای عملکرد در یک پایگاه داده رابطه ای است که به اسکن کامل جدول نیاز دارد. در یک پایگاه داده رابطه‌ای، پرس و جوی که به اسکن کامل جدول نیاز دارد، معادل یک شنونده عکس فوری است که مجموعه‌ای با شدت بالا را تماشا می‌کند. ممکن است در مقایسه با پرس و جوی که پایگاه داده می تواند با استفاده از یک نمایه خاص تر ارائه دهد کند عمل کند. یک پرس و جو با یک نمایه خاص تر مانند یک شنونده عکس فوری است که یک سند واحد یا مجموعه ای را که کمتر تغییر می کند تماشا می کند. برای درک بهتر رفتار و نیاز مورد استفاده خود، باید برنامه خود را آزمایش کنید.

به سوالات نظرسنجی سریع ادامه دهید

یکی دیگر از بخش‌های کلیدی پرس‌وجوهای بلادرنگ پاسخگو این است که مطمئن شوید که کوئری نظرسنجی برای راه‌اندازی داده‌ها سریع و کارآمد است. اولین باری که یک شنونده عکس فوری جدید متصل می شود، شنونده باید کل مجموعه نتیجه را بارگیری کند و آن را به دستگاه کاربر ارسال کند. پرس و جوهای آهسته باعث می شود برنامه شما کمتر پاسخگو باشد. این شامل، برای مثال، پرس و جوهایی است که سعی در خواندن بسیاری از اسناد دارند یا پرس و جوهایی که از نمایه های مناسب استفاده نمی کنند.

یک شنونده همچنین ممکن است تحت شرایطی از حالت گوش دادن به حالت نظرسنجی برگردد. این به طور خودکار اتفاق می افتد و برای SDK ها و برنامه شما شفاف است. شرایط زیر ممکن است باعث ایجاد وضعیت نظرسنجی شود:

  • این سیستم به دلیل تغییرات بار ، یک Chanloglog را دوباره متعادل می کند .
  • هات‌اسپات باعث نوشتن ناموفق یا تأخیر در پایگاه داده می‌شود.
  • راه اندازی مجدد سرور موقت به طور موقت بر شنوندگان تأثیر می گذارد.

اگر درخواست های نظرسنجی شما به اندازه کافی سریع باشد، وضعیت نظرسنجی برای کاربران برنامه شما شفاف می شود.

از شنوندگان با عمر طولانی حمایت کنید

باز کردن و زنده نگه داشتن شنوندگان تا زمانی که ممکن است اغلب مقرون به صرفه ترین راه برای ساخت برنامه ای است که از Cloud Firestore استفاده می کند. هنگام استفاده از Cloud Firestore ، برای اسنادی که به برنامه خود بازگردانده می شوند و نه برای حفظ یک اتصال باز، صورتحساب دریافت می کنید. یک شنونده عکس فوری با عمر طولانی فقط داده هایی را می خواند که برای ارائه پرس و جو در طول عمرش نیاز دارد. این شامل یک عملیات نظرسنجی اولیه و به دنبال آن اعلان هایی است که داده ها واقعاً تغییر می کنند. از سوی دیگر، کوئری‌های تک‌شات، داده‌هایی را که ممکن است از آخرین باری که برنامه درخواست را اجرا کرده است، تغییر نکرده باشد، دوباره می‌خوانند.

در مواردی که برنامه شما باید میزان بالایی از داده مصرف کند، شنوندگان عکس فوری ممکن است مناسب نباشند. به عنوان مثال، اگر مورد استفاده شما اسناد زیادی را در هر ثانیه از طریق یک اتصال برای مدت زمان طولانی منتقل می کند، ممکن است بهتر باشد پرس و جوهای تک شات که با فرکانس کمتر اجرا می شوند را انتخاب کنید.

بعد چه است