1. مقدمة

Cloud Run هي منصة مُدارة تتيح لك تشغيل حاويات لا يتم تسجيل بياناتها ويمكن استدعاؤها من خلال طلبات HTTP. Cloud Run هو نظام أساسي بدون خادم: فهو يجرّد جميع عمليات إدارة البنية الأساسية، ما يتيح لك التركيز على الأمور الأكثر أهمية، أي إنشاء تطبيقات رائعة.
تم إنشاء هذه الخدمة باستخدام Knative، ما يتيح لك اختيار تشغيل الحاويات إما بشكل مُدار بالكامل باستخدام Cloud Run، أو في مجموعة Google Kubernetes Engine باستخدام Cloud Run على GKE.
الهدف من هذا الدرس التطبيقي حول الترميز هو إنشاء صورة حاوية ونشرها على Cloud Run.
2. الإعداد والمتطلبات
إعداد البيئة بالسرعة التي تناسبك
- سجِّل الدخول إلى Google Cloud Console وأنشِئ مشروعًا جديدًا أو أعِد استخدام مشروع حالي. إذا لم يكن لديك حساب على Gmail أو Google Workspace، عليك إنشاء حساب.



- اسم المشروع هو الاسم المعروض للمشاركين في هذا المشروع. وهي سلسلة أحرف لا تستخدمها Google APIs. ويمكنك تعديلها في أي وقت.
- رقم تعريف المشروع هو معرّف فريد في جميع مشاريع Google Cloud ولا يمكن تغييره بعد ضبطه. تنشئ Cloud Console تلقائيًا سلسلة فريدة، ولا يهمّك عادةً ما هي. في معظم دروس البرمجة، عليك الرجوع إلى رقم تعريف مشروعك (يُشار إليه عادةً باسم
PROJECT_ID). إذا لم يعجبك رقم التعريف الذي تم إنشاؤه، يمكنك إنشاء رقم تعريف عشوائي آخر. يمكنك بدلاً من ذلك تجربة اسم مستخدم من اختيارك ومعرفة ما إذا كان متاحًا. لا يمكن تغيير هذا الخيار بعد هذه الخطوة وسيظل ساريًا طوال مدة المشروع. - للعلم، هناك قيمة ثالثة، وهي رقم المشروع، تستخدمها بعض واجهات برمجة التطبيقات. يمكنك الاطّلاع على مزيد من المعلومات عن كل هذه القيم الثلاث في المستندات.
- بعد ذلك، عليك تفعيل الفوترة في Cloud Console لاستخدام موارد/واجهات برمجة تطبيقات Cloud. لن تكلفك تجربة هذا الدرس التطبيقي حول الترميز الكثير، إن وُجدت أي تكلفة على الإطلاق. لإيقاف الموارد وتجنُّب تحمّل تكاليف تتجاوز هذا البرنامج التعليمي، يمكنك حذف الموارد التي أنشأتها أو حذف المشروع. يمكن لمستخدمي Google Cloud الجدد الاستفادة من برنامج الفترة التجريبية المجانية بقيمة 300 دولار أمريكي.
Google Cloud Shell
على الرغم من إمكانية تشغيل Google Cloud عن بُعد من الكمبيوتر المحمول، سنستخدم في هذا الدرس التطبيقي حول الترميز Google Cloud Shell، وهي بيئة سطر أوامر تعمل في السحابة الإلكترونية.
Cloud Shell هي بيئة تطوير وعمليات على الإنترنت يمكن الوصول إليها من أي مكان باستخدام المتصفح. يمكنك إدارة مواردك باستخدام وحدة التحكّم على الإنترنت المحمَّلة مسبقًا بأدوات مثل أداة سطر الأوامر gcloud وkubectl وغير ذلك. يمكنك أيضًا تطوير تطبيقاتك المستندة إلى السحابة الإلكترونية وإنشاؤها وتصحيح أخطائها ونشرها باستخدام محرّر Cloud Shell على الإنترنت.
يتم تحميل هذا الجهاز الافتراضي بجميع أدوات التطوير التي تحتاج إليها. توفّر هذه الخدمة دليلًا منزليًا دائمًا بسعة 5 غيغابايت وتعمل مباشرةً في Google Cloud، ما يؤدي إلى تحسين أداء الشبكة والمصادقة بشكل كبير. وهذا يعني أنّ كل ما تحتاجه لهذا الدرس التطبيقي حول الترميز هو متصفّح (نعم، يمكن استخدامه على جهاز Chromebook).
- لتفعيل Cloud Shell من Cloud Console، ما عليك سوى النقر على تفعيل Cloud Shell :

إذا كانت هذه هي المرة الأولى التي تبدأ فيها Cloud Shell، ستظهر لك شاشة وسيطة توضّح ماهيتها. إذا ظهرت لك شاشة وسيطة، انقر على متابعة.

لن يستغرق توفير البيئة سوى بضع ثوانٍ :

بعد الاتصال بـ Cloud Shell، من المفترض أن تظهر لك رسالة تفيد بأنّه تمّت مصادقتك :
gcloud auth list
ناتج الأمر
Credentialed Accounts ACTIVE: * ACCOUNT: <my-account>@<mydomain>
يجب أيضًا ضبط المشروع مسبقًا على PROJECT_ID (بافتراض أنّك اخترت مشروعًا في وحدة تحكّم الويب) :
gcloud config list project
ناتج الأمر
[core] project = <PROJECT_ID>
إذا لم يتم ضبط المشروع لسبب ما، ما عليك سوى تنفيذ الأمر التالي:
gcloud config set project <PROJECT_ID>
هل تبحث عن PROJECT_ID؟ اطّلِع على القائمة المنسدلة في أعلى Cloud Console :

يمكنك أيضًا الاطّلاع على تفاصيل مشروعك باستخدام قسم "الإعدادات والأدوات":

يضبط Cloud Shell أيضًا بعض متغيرات البيئة تلقائيًا، ما قد يكون مفيدًا عند تنفيذ الأوامر المستقبلية.
echo $GOOGLE_CLOUD_PROJECT
ناتج الأمر
<PROJECT_ID>
- أخيرًا، يمكنك ضبط المنطقة التلقائية :
gcloud config set compute/zone us-central1-f
يمكنك اختيار مناطق مختلفة. لمزيد من المعلومات، يُرجى الاطّلاع على الأقاليم والمناطق.
تفعيل Cloud Run API
من Cloud Shell، فعِّل Cloud Run API :
gcloud services enable run.googleapis.com
من المفترض أن يؤدي ذلك إلى ظهور رسالة نجاح مشابهة لما يلي :
Operation "operations/acf.cc11852d-40af-47ad-9d59-477a12847c9e" finished successfully.
3- كتابة نموذج الطلب
سننشئ تطبيقًا بسيطًا بلغة ASP.NET C# يستجيب لطلبات HTTP.
لإنشاء تطبيقك، استخدِم أداة سطر الأوامر dotnet في Cloud Shell:
dotnet new web -o helloworld-csharp
التغيير إلى دليل helloworld-csharp:
cd helloworld-csharp
بعد ذلك، عدِّل Program.cs ليتطابق مع ما يلي:
var builder = WebApplication.CreateBuilder(args);
var port = Environment.GetEnvironmentVariable("PORT") ?? "8080";
var url = $"http://0.0.0.0:{port}";
builder.WebHost.UseUrls(url);
var app = builder.Build();
app.MapGet("/", () => "Hello World!");
app.Run();
تنشئ هذه التعليمات البرمجية خادم ويب أساسيًا يستمع إلى المنفذ المحدّد بواسطة متغيّر البيئة PORT ويردّ بالرسالة Hello World.
يمكنك اختبار التطبيق من خلال تشغيله محليًا في Cloud Shell. من المفترض أن تظهر لك عملية الاستماع على المنفذ 8080:
$ dotnet run Using launch settings from /home/atameldev/helloworld-csharp/Properties/launchSettings.json... Hosting environment: Development Content root path: /home/atameldev/helloworld-csharp Now listening on: http://0.0.0.0:8080 Application started. Press Ctrl+C to shut down.
4. النشر على Cloud Run
انشر تطبيقك على Cloud Run باستخدام الأمر التالي:
gcloud run deploy hello-world \
--allow-unauthenticated \
--region us-central1 \
--source .
-
hello-worldهو اسم الخدمة. - تعمل العلامة
allow-unauthenticatedعلى نشر الخدمة كخدمة متاحة للجميع بدون متطلبات مصادقة. us-central1هي المنطقة التي سيتم نشر التطبيق فيها.- يحدّد العلامة
sourceموقع المصدر الذي سيتم الإنشاء منه. يستخدم Cloud Run حِزم الإنشاء لإنشاء حاوية تلقائيًا من رمز المصدر.
انتظِر بضع دقائق حتى يكتمل النشر. عند النجاح، يعرض سطر الأوامر عنوان URL للخدمة :
Service [hello-world] revision [hello-world-00001-yos] has been deployed and is serving 100 percent of traffic. Service URL: https://helloworld-wdl7fdwaaa-uc.a.run.app
يمكنك الآن الانتقال إلى الحاوية التي تم نشرها من خلال فتح عنوان URL الخاص بالخدمة في متصفّح ويب :

تهانينا! لقد نشرت للتو تطبيقًا مضمّنًا في صورة حاوية على Cloud Run. توسّع خدمة Cloud Run نطاق صورة الحاوية تلقائيًا وأفقيًا للتعامل مع الطلبات المستلَمة، ثم تقلّل نطاقها عند انخفاض الطلب. لن تدفع إلا مقابل وحدة المعالجة المركزية والذاكرة والشبكة المستخدَمة أثناء معالجة الطلب.
5- حان وقت التنظيف
يمكنك إما حذف مشروعك على Google Cloud Platform لتجنُّب تحمّل الرسوم، ما سيؤدي إلى إيقاف الفوترة لجميع الموارد المستخدَمة في هذا المشروع، أو يمكنك ببساطة حذف خدمة Cloud Run باتّباع الخطوات التالية:
gcloud run services delete helloworld
6. ما هي الخطوات التالية؟
تتمثّل الخطوة التالية الجيدة في النشر على Cloud Run على GKE.
لمزيد من المعلومات حول إنشاء حاوية HTTP لا يتم تسجيل بياناتها ومناسبة لـ Cloud Run من مصدر الرمز البرمجي ونقلها إلى Container Registry، يُرجى الاطّلاع على: