يمكنك إقران Cloud Run مع Firebase Hosting لإنشاء المحتوى الديناميكي وعرضه أو إنشاء واجهات برمجة تطبيقات REST كخدمات صغيرة.
باستخدام Cloud Run، يمكنك نشر تطبيق مُحزم في صورة حاوية. بعد ذلك، يمكنك استخدام "Firebase Hosting" لتوجيه طلبات HTTPS لتشغيل تطبيقك المُحمَّل.
- يتيح لك Cloud Run استخدام عدة لغات (بما في ذلك Go وNode.js وPython وJava)، ما يمنحك المرونة في استخدام لغة البرمجة وإطار العمل المفضّلَين لديك.
- Cloud Run تتم زيادة حجم صورة الحاوية بشكل تلقائي وأفقي لمعالجة الطلبات الواردة، ثم يتم تقليل حجمها عندما ينخفض الطلب.
- تدفع فقط مقابل وحدة المعالجة المركزية (CPU) والذاكرة والشبكة المستخدَمة أثناء معالجة الطلبات.
للاطّلاع على أمثلة لحالات الاستخدام ونماذج لتطبيق Cloud Run المدمج مع Firebase Hosting، يُرجى الانتقال إلى نظرة عامة حول تكنولوجيا السحابة غير المزوّدة بخادم.
يوضّح لك هذا الدليل كيفية:
- كتابة تطبيق Hello World بسيط
- تضمين تطبيق في حاوية وتحميله إلى Container Registry
- نشر صورة الحاوية على Cloud Run
- توجيه طلبات Hosting إلى تطبيقك المستند إلى حاويات
لاحظ أنه لتحسين أداء عرض المحتوى الديناميكي، يمكنك ضبط إعدادات ذاكرة التخزين المؤقت اختياريًا.
قبل البدء
قبل استخدام Cloud Run، عليك إكمال بعض المهام الأولية،
بما في ذلك إعداد حساب Cloud Billing وتفعيل واجهة برمجة التطبيقات Cloud Run
وتثبيت أداة سطر الأوامر gcloud
.
إعداد الفوترة لمشروعك
يوفّر Cloud Run حصة استخدام مجانية، ولكن لا يزال عليك امتلاك حساب Cloud Billing مرتبط بمشروعك على Firebase لاستخدام Cloud Run أو تجربته.
تفعيل واجهة برمجة التطبيقات وتثبيت حزمة تطوير البرامج (SDK)
فعِّل واجهة برمجة التطبيقات Cloud Run في وحدة تحكّم Google APIs:
افتح صفحة واجهة برمجة التطبيقات Cloud Run في وحدة تحكم واجهات برمجة التطبيقات في Google.
اختَر مشروعك على Firebase عندما يُطلب منك ذلك.
انقر على تفعيل في صفحة واجهة برمجة التطبيقات Cloud Run.
تأكَّد من ضبط أداة
gcloud
للمشروع الصحيح:gcloud config list
الخطوة 1: كتابة نموذج الطلب
يُرجى العِلم أنّ Cloud Run تتيح استخدام العديد من اللغات الأخرى بالإضافة إلى اللغات المعروضة في العيّنة التالية.
انتقال
أنشئ دليلاً جديدًا باسم
helloworld-go
، ثم غيِّر الدليل إلى:mkdir helloworld-go
cd helloworld-go
أنشئ ملفًا جديدًا باسم
helloworld.go
، ثم أضِف الرمز التالي:ينشئ هذا الرمز خادم ويب أساسيًا يستمع إلى المنفذ المحدد من خلال متغير البيئة
PORT
.
اكتمل تطبيقك وأصبح جاهزًا لنقله إلى حاويات وتحميله إلى Container Registry.
Node.js
أنشئ دليلاً جديدًا باسم
helloworld-nodejs
، ثم غيِّر الدليل إلى:mkdir helloworld-nodejs
cd helloworld-nodejs
أنشئ ملف
package.json
يتضمّن المحتوى التالي:أنشئ ملفًا جديدًا باسم
index.js
، ثم أضِف الرمز التالي:تنشئ هذه التعليمات البرمجية خادم ويب أساسيًا يستمع إلى المنفذ المحدَّد من خلال متغيّر البيئة
PORT
.
اكتمل تطبيقك وأصبح جاهزًا للحاويات وتحميله إلى Container Registry.
Python
أنشئ دليلاً جديدًا باسم
helloworld-python
، ثم غيِّر الدليل إلى:mkdir helloworld-python
cd helloworld-python
أنشئ ملفًا جديدًا باسم
app.py
، ثم أضِف الرمز التالي:تنشئ هذه التعليمات البرمجية خادم ويب أساسيًا يستمع إلى المنفذ المحدَّد من خلال متغيّر البيئة
PORT
.
اكتمل تطبيقك وأصبح جاهزًا للحاويات وتحميله إلى Container Registry.
جافا
ثبِّت Java SE 8 أو إصدار أحدث من JDK وCURL.
يُرجى العِلم أنّنا نحتاج فقط إلى إجراء ذلك لإنشاء مشروع الويب الجديد في الخطوة التالية. سيقوم الملف الشامل، الموصوف لاحقًا، بتحميل جميع التبعيات في الحاوية.
من وحدة التحكّم، أنشِئ مشروع ويب جديدًا فارغًا باستخدام cURL ثم أوامر فكّ الضغط:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zip
unzip helloworld.zip
يؤدي ذلك إلى إنشاء مشروع SpringBoot.
عدِّل فئة
SpringBootApplication
فيsrc/main/java/com/example/helloworld/HelloworldApplication.java
من خلال إضافة@RestController
لمعالجة تعيين/
، وأضِف أيضًا حقل@Value
لتقديم متغيّر البيئةTARGET
:تنشئ هذه التعليمات البرمجية خادم ويب أساسيًا يستمع إلى المنفذ المحدَّد من خلال متغيّر البيئة
PORT
.
اكتمل تطبيقك وأصبح جاهزًا لنقله إلى حاويات وتحميله إلى Container Registry.
الخطوة 2: حجز مساحة تخزين لتطبيق وتحميله إلى Container Registry
يمكنك احتواء نموذج التطبيق من خلال إنشاء ملف جديد باسم
Dockerfile
في الدليل نفسه مثل الملفات المصدر. انسخ المحتوى التالي في ملفك.انتقال
Node.js
Python
جافا
أنشئ صورة الحاوية باستخدام Cloud Build من خلال تنفيذ العبارة التالية من الدليل الذي يحتوي على Dockerfile:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
بعد نجاح العملية، ستظهر لك رسالة SUCCESS (تم بنجاح) تحتوي على اسم الصورة
(gcr.io/PROJECT_ID/helloworld
).
صورة الحاوية مخزَّنة الآن في Container Registry ويمكن إعادة استخدامها إذا لزم الأمر.
ملاحظة: بدلاً من Cloud Build، يمكنك استخدام إصدار مثبَّت محليًا من Docker للقيام بإنشاء الحاوية محليًا.
الخطوة 3: نشر صورة الحاوية على Cloud Run
يمكنك النشر باستخدام الأمر التالي:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
عندما يُطلب منك ذلك:
- اختَر منطقة (مثل
us-central1
). - أكِّد اسم الخدمة (على سبيل المثال،
helloworld
). - الردّ
Y
على السماح بطلبات الاستدعاء غير المعتمَدة
- اختَر منطقة (مثل
للحصول على أفضل أداء، يمكنك تجميع خدمة Cloud Run من خلال Hosting باستخدام المناطق التالية:
us-west1
us-central1
us-east1
europe-west1
asia-east1
تتوفّر إعادة الكتابة إلى Cloud Run من Hosting في المناطق التالية:
asia-east1
asia-east2
asia-northeast1
asia-northeast2
asia-northeast3
asia-south1
asia-south2
asia-southeast1
asia-southeast2
australia-southeast1
australia-southeast2
europe-central2
europe-north1
europe-southwest1
europe-west1
europe-west12
europe-west2
europe-west3
europe-west4
europe-west6
europe-west8
europe-west9
me-central1
me-west1
northamerica-northeast1
northamerica-northeast2
southamerica-east1
southamerica-west1
us-central1
us-east1
us-east4
us-east5
us-south1
us-west1
us-west2
us-west3
us-west4
us-west1
us-central1
us-east1
europe-west1
asia-east1
يُرجى الانتظار بضع لحظات إلى أن تكتمل عملية النشر. عند نجاح العملية، يعرض سطر الأوامر عنوان URL للخدمة. على سبيل المثال:
https://helloworld-RANDOM_HASH-us-central1.a.run.app انتقِل إلى الحاوية المنشورة من خلال فتح عنوان URL للخدمة في متصفّح ويب.
سترشدك الخطوة التالية إلى كيفية الوصول إلى هذا التطبيق المُنشئ في حاوية من عنوان URL لملف Firebase Hosting حتى يتمكّن من إنشاء محتوى ديناميكي ل موقعك الإلكتروني المستضاف على Firebase.
الخطوة 4: توجيه طلبات الاستضافة إلى تطبيقك المُنشئ في حاوية
باستخدام قواعد إعادة الكتابة، يمكنك توجيه الطلبات التي تتطابق مع أنماط معيّنة إلى وجهة واحدة.
يوضّح المثال التالي كيفية توجيه جميع الطلبات من الصفحة /helloworld
على موقع Hosting الإلكتروني لبدء تشغيل مثيل الحاوية helloworld
وتشغيله.
تأكَّد مما يلي:
أن يكون لديك أحدث إصدار من واجهة برمجة التطبيقات Firebase
لقد تم إعداد Firebase Hosting.
للحصول على تعليمات مفصّلة حول تثبيت واجهة برمجة التطبيقات وبدء استخدام Hosting، يُرجى الاطّلاع على دليل بدء استخدام Hosting.
افتح ملف
firebase.json
.أضِف إعدادات
rewrite
التالية ضمن قسمhosting
:"hosting": { // ... // Add the "rewrites" attribute within "hosting" "rewrites": [ { "source": "/helloworld", "run": { "serviceId": "helloworld", // "service name" (from when you deployed the container image) "region": "us-central1", // optional (if omitted, default is us-central1) "pinTag": true // optional (see note below) } } ] }
يمكنك نشر إعدادات الاستضافة على موقعك الإلكتروني من خلال تنفيذ العبارة التالية من جذر دليل المشروع:
firebase deploy --only hosting
يمكن الآن الوصول إلى حاويتك عبر عناوين URL التالية:
النطاقات الفرعية في Firebase:
PROJECT_ID.web.app/
وPROJECT_ID.firebaseapp.com/
أي نطاقات مخصّصة مرتبطة:
CUSTOM_DOMAIN/
انتقِل إلى صفحة إعدادات Hosting للحصول على مزيد من التفاصيل حول قواعد إعادة الكتابة. يمكنك أيضًا التعرّف على ترتيب أولوية الردود لإعدادات Hosting المختلفة.
الاختبار على الجهاز
أثناء التطوير، يمكنك تشغيل صورة الحاوية واختبارها محليًا. للحصول على تعليمات تفصيلية، يُرجى الانتقال إلى مستندات Cloud Run.
الخطوات التالية
إعداد ميزة التخزين المؤقّت لمحتوى موقعك الإلكتروني الديناميكي على شبكة توصيل محتوى عالمية
التفاعل مع خدمات Firebase الأخرى باستخدام حزمة تطوير البرامج (SDK) لإدارة Firebase
اطّلِع على مزيد من المعلومات عن Cloud Run، بما في ذلك الأدلة التفصيلية حول كيفية إعداد الحاويات وإدارتها وضبطها.
راجِع الأسعار والحصص والحدود في Cloud Run.