يمكنك إقران Cloud Run مع استضافة Firebase لإنشاء المحتوى الديناميكي وعرضه، أو إنشاء واجهات برمجة تطبيقات REST كخدمات مصغَّرة.
باستخدام Cloud Run، يمكنك نشر تطبيق في حزمة في صورة حاوية. وبعد ذلك، يمكنك باستخدام "استضافة Firebase" توجيه طلبات HTTPS لتشغيل تطبيقك المُحوَّل إلى حاوية.
- يدعم Cloud Run عدّة لغات (بما في ذلك Go وNode.js وPython وJava)، مما يمنحك المرونة لاستخدام لغة البرمجة وإطار العمل من اختيارك.
- يعمل Cloud Run تلقائيًا وأفقيًا على ضبط صورة الحاوية لمعالجة الطلبات المُستلَمة، ثم يتم تقليصه عند انخفاض الطلب.
- ما عليك سوى الدفع مقابل وحدة المعالجة المركزية والذاكرة والاتصال بالشبكات التي يتم استهلاكها أثناء معالجة الطلبات.
على سبيل المثال، حالات الاستخدام والعينات لنظام Cloud Run الذي تم دمجه مع "استضافة Firebase"، يمكنك الانتقال إلى نظرة عامة على المحتوى بدون خادم.
يوضّح لك هذا الدليل كيفية تنفيذ ما يلي:
- كتابة تطبيق Hello World بسيط
- إضافة تطبيق إلى Container Registry وتحميله إلى Container Registry
- نشر صورة الحاوية في Cloud Run
- طلبات الاستضافة المباشرة لتطبيقك المضمّن
لاحظ أنه لتحسين أداء عرض المحتوى الديناميكي، يمكنك ضبط إعدادات ذاكرة التخزين المؤقت اختياريًا.
قبل البدء
قبل استخدام Cloud Run، يجب إكمال بعض المهام الأولية،
بما في ذلك إعداد حساب فوترة في السحابة الإلكترونية وتفعيل واجهة برمجة التطبيقات في Cloud Run
وتثبيت أداة سطر الأوامر gcloud
.
إعداد الفوترة لمشروعك
يوفّر Cloud Run حصة استخدام مجانية، ولكن يجب أن يكون لديك حساب فوترة في السحابة الإلكترونية مرتبط بمشروعك على Firebase حتى تتمكّن من استخدام Cloud Run أو تجربته.
تفعيل واجهة برمجة التطبيقات وتثبيت حزمة تطوير البرامج (SDK)
تفعيل Cloud Run API في وحدة تحكُّم Google APIs:
افتح صفحة Cloud Run API في وحدة تحكُّم Google APIs.
اختَر مشروعك على Firebase عندما يُطلب منك ذلك.
انقر على تفعيل في صفحة Cloud Run API.
تثبيت وإعداد حزمة SDK للسحابة الإلكترونية
تأكَّد من إعداد أداة
gcloud
للمشروع الصحيح:gcloud config list
الخطوة 1: كتابة نموذج التطبيق
تجدر الإشارة إلى أن Cloud Run يدعم العديد من اللغات الأخرى بالإضافة إلى اللغات المذكورة في النموذج التالي.
Go
أنشِئ دليلاً جديدًا باسم
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
ثبِّت Java SE 8 أو أحدث JDK وCURL.
لاحظ أننا نحتاج فقط إلى القيام بذلك لإنشاء مشروع الويب الجديد في الخطوة التالية. سيقوم ملف Dockerfile، الموصوف لاحقًا، بتحميل جميع التبعيات في الحاوية.
من وحدة التحكم، أنشِئ مشروع ويب جديدًا فارغًا باستخدام 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
في الدليل نفسه كملفات المصدر. انسخ المحتوى التالي في ملفك.Go
Node.js
Python
Java
أنشئ صورة الحاوية باستخدام Cloud Build عن طريق تشغيل الأمر التالي من الدليل الذي يحتوي على Dockerfile:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
عند إتمام العملية بنجاح، ستظهر لك رسالة "تم بنجاح" تحتوي على اسم الصورة
(gcr.io/PROJECT_ID/helloworld
).
يتم الآن تخزين صورة الحاوية في Container Registry ويمكن إعادة استخدامها عند الرغبة في ذلك.
تجدر الإشارة إلى أنّه يمكنك استخدام إصدار مثبَّت محليًا من Docker بدلاً من Cloud Build من أجل إنشاء حاويتك محليًا.
الخطوة 3: نشر صورة الحاوية في Cloud Run
النشر باستخدام الأمر التالي:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
عندما يُطلب منك ذلك:
- اختيار منطقة (على سبيل المثال
us-central1
) - تأكيد اسم الخدمة (على سبيل المثال،
helloworld
) - الرد على
Y
للسماح بالاستدعاءات التي لم تتم مصادقتها
- اختيار منطقة (على سبيل المثال
للحصول على أفضل أداء، يمكنك تجميع خدمة Cloud Run مع ميزة "الاستضافة" باستخدام المناطق التالية:
us-west1
us-central1
us-east1
europe-west1
asia-east1
تتوفر عمليات إعادة الكتابة إلى Cloud Run من "الاستضافة" في المناطق التالية:
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 حتى يتمكّن من إنشاء محتوى ديناميكي لموقعك الإلكتروني الذي يستضيفه Firebase.
الخطوة 4: طلبات الاستضافة المباشرة لتطبيقك المضمّن
باستخدام قواعد إعادة الكتابة، يمكنك توجيه الطلبات التي تتطابق مع أنماط محددة إلى وجهة واحدة.
يوضِّح المثال التالي كيفية توجيه جميع الطلبات من صفحة /helloworld
على الموقع الإلكتروني للاستضافة لبدء تشغيل مثيل حاوية helloworld
وتشغيله.
تأكَّد مما يلي:
لقد أعددت "استضافة Firebase".
للحصول على تعليمات تفصيلية حول تثبيت واجهة سطر الأوامر وتهيئة الاستضافة، راجع دليل البدء للاستضافة.
افتح ملف
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/
انتقِل إلى صفحة "ضبط الاستضافة" للاطّلاع على مزيد من التفاصيل حول قواعد إعادة الكتابة. يمكنك أيضًا التعرف على ترتيب أولويات الاستجابات لإعدادات الاستضافة المختلفة.
الاختبار محليًا
أثناء التطوير، يمكنك تشغيل صورة الحاوية واختبارها محليًا. للحصول على تعليمات تفصيلية، يُرجى الانتقال إلى مستندات Cloud Run.
الخطوات اللاحقة
إعداد التخزين المؤقت للمحتوى الديناميكي على شبكة توصيل محتوى (CDN) عالمية
التفاعل مع خدمات Firebase الأخرى باستخدام حزمة SDK لمشرف Firebase
تعرّف على المزيد من المعلومات حول Cloud Run، بما في ذلك أدلة تفصيلية حول كيفية الاستخدام لإعداد الحاويات وإدارتها وإعدادها.
راجِع التسعير والحصص والحدود المتعلقة بنظام التشغيل Cloud.