۱. مقدمه
در این آزمایشگاه کد، شما یاد خواهید گرفت که چگونه یک برنامه فولاستک را با استفاده از مرکز طراحی برنامه ابری گوگل (ADC) مستقر کنید. شما برنامه "The Cymbal London Concierge" را مستقر خواهید کرد که شامل یک رابط کاربری Vue 3، یک رابط کاربری FastAPI و یک سرور MCP است که دادههای برنامه را در خود نگه میدارد.
ADC به شما امکان میدهد معماری برنامه خود را به صورت بصری تعریف کنید و آن را به عنوان یک واحد واحد مستقر کنید و وابستگیها و اتصالات را به طور خودکار مدیریت کنید.
کاری که انجام خواهید داد
- راه اندازی مرکز طراحی اپلیکیشن
- اجزای برنامه را به صورت بصری مونتاژ کنید.
- معماری برنامه را مستقر کنید.
- برنامه در حال اجرا را تأیید کنید.
- تأیید کنید که برنامه در App Hub ثبت شده است.
- معیارهای برنامه، ردیابیها و گزارشها را در نظارت بر برنامه تأیید کنید.
آنچه نیاز دارید
- یک مرورگر وب مانند کروم .
- یک پروژه گوگل کلود با قابلیت پرداخت.
این آزمایشگاه کد برای توسعهدهندگان در تمام سطوح، از جمله مبتدیان، مناسب است.
مدت زمان تخمینی: ۴۵ دقیقه هزینه تخمینی: کمتر از ۲ دلار آمریکا
۲. راهاندازی
راهاندازی پروژه
ایجاد یک پروژه ابری گوگل
- در کنسول گوگل کلود ، در صفحه انتخاب پروژه، یک پروژه گوگل کلود را انتخاب یا ایجاد کنید .
- مطمئن شوید که صورتحساب برای پروژه ابری شما فعال است. یاد بگیرید که چگونه بررسی کنید که آیا صورتحساب در یک پروژه فعال است یا خیر .
شروع پوسته ابری
Cloud Shell یک محیط خط فرمان است که در Google Cloud اجرا میشود و ابزارهای لازم از قبل روی آن بارگذاری شدهاند.
- روی فعال کردن Cloud Shell در بالای کنسول Google Cloud کلیک کنید.
- پس از اتصال به Cloud Shell، احراز هویت خود را تأیید کنید:
gcloud auth list - تأیید کنید که پروژه شما پیکربندی شده است:
gcloud config get project - اگر پروژه شما مطابق انتظار تنظیم نشده است، آن را تنظیم کنید:
export PROJECT_ID=<YOUR_PROJECT_ID> gcloud config set project $PROJECT_ID
۳. مرکز طراحی اپلیکیشن راهاندازی کنید
قبل از اینکه بتوانید برنامه خود را مونتاژ کنید، باید فضای کاری خود را در ADC تنظیم کنید.
- در کنسول گوگل کلود، عبارت Application Design Center را جستجو کنید و به آن بروید.
- اگر این اولین بار است که از ADC در این پروژه استفاده میکنید، یک صفحه تنظیمات مشاهده خواهید کرد.
- روی رفتن به تنظیمات کلیک کنید.

- اگر API های مورد نیاز از قبل فعال نشده باشند، از شما خواسته میشود که آنها را فعال کنید. برای ادامه، روی فعال کردن کلیک کنید.

۴. بررسی ویژگیهای ADC
در این تمرین، اجزای اصلی ADC را یاد میگیرید: فضاها، کاتالوگها و قالبها.
فضاهای ADC
یک فضا (Space) مکانی برای ایجاد قالبها و استقرار برنامهها است. هر فضا متعلق به یک پروژه Google Cloud است. ADC در طول راهاندازی اولیه یک فضای پیشفرض ایجاد میکند، اما شما میتوانید بعداً فضاهای دیگری را در مناطق مختلف ایجاد کنید.
برای مشاهده فضاهای خود از طریق ترمینال، مراحل زیر را انجام دهید:
- روی «باز کردن ویرایشگر» در نوار ابزار Cloud Shell کلیک کنید یا از ترمینال استفاده کنید.
- دستور زیر را اجرا کنید:
gcloud alpha design-center spaces list \
--project="your PROJECT ID" \
--location=us-central1
شما باید خروجیای شبیه به این ببینید که نشان میدهد فضای پیشفرض برای منطقه وجود دارد.
createTime: '20XXXX-XX-XXT09:19:29.456016967Z'
displayName: default-space
enableGcpSharedTemplates: true
name: projects/your-project-id/locations/us-central1/spaces/default-space
۵. الگو را مونتاژ کنید
در این مرحله، شما نقش مهندس تیم پلتفرم را بر عهده خواهید گرفت. هدف شما ایجاد یک الگوی قابل استفاده مجدد، امن و سازگار برای برنامههای عامل در سازمانتان است. شما اجزا را اضافه کرده و محدودیتهایی را پیکربندی خواهید کرد تا اطمینان حاصل شود که هر برنامهای که از این الگو مستقر میشود، با سیاستهای ابری شرکت شما مطابقت دارد.
۱. یک طرح جدید ایجاد کنید
- در کنسول ADC، روی Templates > Create Template کلیک کنید.
- نام الگوی خود را
simple-3-tier-agentic-appبگذارید، زیرا این الگو برای استقرار برنامهCymbal London Conciergeو سایر برنامههای مشابه استفاده خواهد شد.
۲. سرور Data MCP را اضافه کنید
این کامپوننت تعاملات پایگاه داده و جستجوی برداری را مدیریت میکند.
- روی افزودن کامپوننت > اجرای ابری (سرویس) کلیک کنید. اگر روی آن کامپوننت کلیک کنید، شناسه کامپوننت را در گوشه بالا سمت راست مشاهده خواهید کرد. این شناسه به شکل
cloud-run-1خواهد بود. میتوانیم با ویرایش آن در نمای کد (که بعداً مورد بحث قرار خواهد گرفت) آن را بهdata-mcp-serverتغییر دهیم، اما بیایید آن را به همین شکل رها کنیم.
- نام سرویس را وارد کنید:
data-mcp-server. - در قسمت «نمایش تنظیمات پیشرفته» ، گزینه « اعضا» را روی
allUsersتنظیم کنید. (نکته: در یک محیط عملیاتی، احتمالاً این مورد را محدود میکنید، اما ما در اینجا برای سادگی کدنویسی از آن استفاده میکنیم.) - در قسمت نمایش تنظیمات پیشرفته ، گزینه تنظیم دسترسی به VPC و گزینه خروجی را روی
PRIVATE_RANGES_ONLYتنظیم کنید. - در صورت تمایل، در قسمت نمایش تنظیمات پیشرفته ، تیک گزینهی «فعال کردن پرومتئوس سایدکار» را بردارید.

- روی ذخیره کلیک کنید.
۳. افزودن بخش پشتیبانی عامل
این برنامه FastAPI است که رفتار عاملمحور را هماهنگ میکند.
- روی افزودن کامپوننت > اجرای ابری (سرویس) کلیک کنید.
- نام آن را
agent-backendبگذارید. - در قسمت نمایش فیلدهای پیشرفته ، گزینه ایجاد حساب کاربری سرویس (Create Service Account) را علامت بزنید و نقشهای زیر را یکی یکی در قسمت نقشهای پروژه حساب کاربری سرویس (Service Account Project Roles) اضافه کنید:
-
roles/monitoring.metricWriter -
roles/logging.logWriter -
roles/cloudtrace.agent -
roles/telemetry.writer -
roles/serviceusage.serviceUsageConsumer. این نقشها به عامل اجازه میدهند تا از Cloud Monitoring، Cloud Logging و Cloud Trace استفاده کند. پیکربندی انطباق: تیم پلتفرم با فهرست کردن صریح نقشهای مورد نیاز، اصل حداقل امتیاز را اجرا میکند.

-
- در قسمت نمایش تنظیمات پیشرفته ، اعضا را روی
allUsersتنظیم کنید. - در قسمت نمایش تنظیمات پیشرفته ، گزینه تنظیم دسترسی به VPC و گزینه خروجی را روی
PRIVATE_RANGES_ONLYتنظیم کنید. - در صورت تمایل، در قسمت نمایش تنظیمات پیشرفته ، تیک گزینهی «فعال کردن پرومتئوس سایدکار» را بردارید.
- با کشیدن یک اتصال از
agent-backendبهdata-mcp-server،agent-backendرا بهdata-mcp-serverمتصل کنید. - روی ذخیره کلیک کنید.
۴. ظاهر (Frontend) را اضافه کنید
رابط کاربری جلویی (front-end UI).
- روی افزودن کامپوننت > اجرای ابری (سرویس) کلیک کنید.
- نام سرویس را وارد کنید:
frontend. - در قسمت نمایش تنظیمات پیشرفته ، تیک گزینه ایجاد حساب کاربری سرویس (Create Service Account) را بردارید.
- در قسمت نمایش تنظیمات پیشرفته ، ورودی را روی
INGRESS_TRAFFIC_INTERNAL_LOADBALANCERتنظیم کنید. پیکربندی انطباق: دسترسی عمومی مستقیم به کانتینر frontend مسدود شده است و ترافیک را مجبور به عبور از متعادلکننده بار میکند. - در قسمت نمایش تنظیمات پیشرفته ، اعضا را روی
allUsersتنظیم کنید.
- در صورت تمایل، در قسمت نمایش تنظیمات پیشرفته ، تیک گزینهی «فعال کردن پرومتئوس سایدکار» را بردارید.
- روی ذخیره کلیک کنید.
- با کشیدن یک اتصال از
frontendبهagent-backend،frontendرا بهagent-backendمتصل کنید.
۵. یک کامپوننت هوش مصنوعی رأسی اضافه کنید
- روی افزودن کامپوننت > Vertex AI کلیک کنید.
- نام آن را
vertex-ai. - با کشیدن دو اتصال از
vertex-aiبه ترتیب بهagent-backendوdata-mcp-server، آن را بهagent-backendوdata-mcp-serverمتصل کنید. نقشهایaiplatform.userاز قبل به حسابهای سرویسagent-backendوdata-mcp-serverبه دلیل اتصال آنها به کامپوننت vertex AI اختصاص داده شدهاند.
۶. متعادلکننده بار سراسری را اضافه کنید
متعادلکننده بار، بخش frontend شما را در معرض اینترنت عمومی قرار میدهد. در ADC، این بخش به یک بخش Backend و یک بخش Frontend تقسیم میشود.
الف. اضافه کردن Backend متعادلکننده بار
- روی افزودن کامپوننت > متعادلسازی بار ابری سراسری (پشتیبان) کلیک کنید.
- نام آن را
galb-backendبگذارید. - روی افزودن اتصال کلیک کنید و آن را به
frontendمتصل کنید.
ب. اضافه کردن رابط کاربری Load Balancer
- روی افزودن کامپوننت > متعادلسازی بار ابری سراسری (ظاهر) کلیک کنید.
- نام آن را
galb-frontendبگذارید. - روی افزودن اتصال کلیک کنید و آن را به
galb-backendمتصل کنید. - با کشیدن یک اتصال از
galb-frontendبهgalb-backend،galb-frontendرا بهgalb-backendمتصل کنید.

الگو را در کاتالوگ به اشتراک بگذارید
یک کاتالوگ به شما امکان میدهد قالبهای برنامه را در فضاهای مختلف به اشتراک بگذارید و مدیریت معماری را امکانپذیر کنید. یک کاتالوگ به عنوان یک مخزن مرکزی برای قالبهایی که توسط تیم پلتفرم ایجاد و برای اشتراکگذاری تأیید شدهاند، عمل میکند. اشتراکگذاری کاتالوگها بین فضاها از تلاشهای تکراری برای پروژههای مشترک جلوگیری میکند و زمان راهاندازی را ساده میکند.
حالا، الگوی خود را به کاتالوگ اضافه کنید:
- روی برگه کاتالوگها کلیک کنید.
- روی افزودن قالبها کلیک کنید و قالب
simple-3-tier-agentic-appرا انتخاب کنید. - روی افزودن به کاتالوگ کلیک کنید.

میتوانید الگوها را در سه مکان پیدا کنید: الگوهای گوگل (الگوهای از پیش تعریفشده)، الگوهای اشتراکی (مشترک در سراسر سازمان شما) و الگوها (طرحهای سفارشی در فضای شما).
۶. برنامه را مستقر کنید
حالا وقت آن رسیده که نقش یک توسعهدهنده اپلیکیشن را بازی کنیم که میخواهد از این الگو برای استقرار اپلیکیشن cymbal-london-concierge استفاده کند.
- در کنسول ADC، قالب را در تب Templates دوباره باز کنید و روی دکمه Configure app کلیک کنید.

- روی ایجاد برنامه جدید کلیک کنید.
- پیکربندی برنامه:
- نام برنامه :
cymbal-london-concierge - پروژه استقرار : شناسه پروژه شما
- منطقه :
us-central1 - ویژگیهای ورودی>محیط :
Development - ویژگیهای ورودی> سطح بحرانی :
Low
- نام برنامه :
- روی ایجاد برنامه کلیک کنید. برای استقرار در محیط عملیاتی، میتوانید «تولید» را برای محیط و «بالا» را برای بحرانی بودن انتخاب کنید. اینها برچسبهایی هستند که به SREها و تیم عملیاتی شما کمک میکنند تا کار روی هر مشکلی که رخ میدهد را مرتب و اولویتبندی کنند.
- این باید صفحه جزئیات استقرار را با الگوی برنامه باز کند. با توجه به اینکه این فقط یک الگو است، ما هنوز باید پیکربندی خاصی را که مختص برنامه ماست اضافه کنیم.
- بیایید ظاهر (frontend) را پیکربندی کنیم. روی کامپوننت ظاهر (frontend) کلیک کنید.
- روی کانتینرها > ویرایش کانتینر کلیک کنید.
- ما باید تصویر کانتینر عمومی را با تصویری که میخواهیم برای برنامه خود استفاده کنیم، جایگزین کنیم.
- تصویر کانتینر را روی این تنظیم کنید:
us-central1-docker.pkg.dev/o11y-movie-guru/london-travel-agency/frontend:codelab-c2c6-v1
- پورت
http1را روی80تنظیم کنید. - متغیرهای محیطی زیر را تنظیم کنید:
-
API_BASE_URL:module.cloud-run-2.service_uri(مطمئن شوید کهcloud-run-2نام کامپوننت backend عامل است، در غیر این صورت آن را با نام واقعی کامپوننت جایگزین کنید)
-
- روی ذخیره کلیک کنید.
- بیایید بخش مدیریت عامل (agent backend) را پیکربندی کنیم. روی کامپوننت agent-backend کلیک کنید.
- روی کانتینرها > ویرایش کانتینر کلیک کنید.
- ما باید تصویر کانتینر عمومی را با تصویری که میخواهیم برای برنامه خود استفاده کنیم، جایگزین کنیم.
- تصویر کانتینر را روی
us-central1-docker.pkg.dev/o11y-movie-guru/london-travel-agency/agent:codelab-c2c6-v1تنظیم کنید. - متغیرهای محیطی زیر را تنظیم کنید:
-
GOOGLE_CLOUD_PROJECT: -
GOOGLE_CLOUD_LOCATION:us-central1 -
DATA_BACKEND_URL:module.cloud-run-1.service_uri(مطمئن شوید کهcloud-run-1نام کامپوننت سرور data mcp است، در غیر این صورت آن را با نام واقعی کامپوننت جایگزین کنید) - پورت
http1را روی8000تنظیم کنید. - روی ذخیره کلیک کنید.
- بیایید سرور data mcp را پیکربندی کنیم. روی کامپوننت data-mcp-server کلیک کنید.
- روی کانتینرها > ویرایش کانتینر کلیک کنید.
- ما باید تصویر کانتینر عمومی را با تصویری که میخواهیم برای برنامه خود استفاده کنیم، جایگزین کنیم.
- تصویر کانتینر را روی این تنظیم کنید:
us-central1-docker.pkg.dev/o11y-movie-guru/london-travel-agency/data_mcp:codelab-c2c6-v1 - متغیرهای محیطی زیر را تنظیم کنید:
-
GOOGLE_CLOUD_PROJECT: -
GOOGLE_CLOUD_LOCATION:us-central1 -
DB_TYPE:sqlite -
EMBEDDING_MODEL:text-embedding-005 - پورت
http1را روی8002تنظیم کنید. - روی ذخیره کلیک کنید.
- برای مشاهده کد terraform مربوط به برنامه، روی دکمه Code در بالای صفحه کلیک کنید. همچنین میتوانید با کلیک روی دکمه Get Code ، کد terraform مربوط به برنامه را دانلود کنید تا در پایگاه کد شما ذخیره شود.

- برای استقرار برنامه، روی دکمهی Deploy در گوشهی بالا سمت راست صفحه کلیک کنید.
- صفحه استقرار از شما میخواهد که یک حساب کاربری سرویس برای فرآیند استقرار ایجاد کنید یا یک حساب کاربری موجود را انتخاب کنید. روی «ایجاد حساب کاربری سرویس» کلیک کنید (این کار به طور خودکار یک نام را پر میکند) و سپس «ادامه » را بزنید. ایجاد یک حساب کاربری سرویس جدید چند ثانیه طول میکشد.

- پس از ایجاد حساب کاربری سرویس، صفحه رفرش میشود و گزینه «انتخاب حساب کاربری سرویس» را به همراه یک علامت تیک در کنار آن مشاهده خواهید کرد.

- سپس در پایین صفحه روی گزینه Deploy کلیک کنید.
- تکمیل این فرآیند چند دقیقه طول خواهد کشید. پس از اتمام استقرار، یک علامت سبز در کنار هر جزء مشاهده خواهید کرد. همچنین میتوانید با کلیک بر روی دکمه «پیوند به گزارشها» که گزارشهای ساخت ابری را باز میکند، وضعیت استقرار را بررسی کنید. ممکن است نمایش این دکمه چند دقیقه طول بکشد.

- شما میتوانید گزارشهای ساخت ابری را مشاهده کنید تا وضعیت استقرار یا هرگونه خطایی که ممکن است هنگام استقرار برنامه رخ دهد را مشاهده کنید. همچنین میتوانید با جستجوی Cloud Build در کنسول Google Cloud و کلیک بر روی History ، مستقیماً به گزارشهای ساخت ابری بروید. استقرار برنامه حدود ۵ تا ۸ دقیقه طول خواهد کشید.

- پس از اتمام استقرار، یک علامت سبز در کنار فیلد وضعیت استقرار مشاهده خواهید کرد.

۷. برنامه را تأیید کنید
بیایید بررسی کنیم که آیا عامل فعال است یا خیر. در بخش خروجیهای صفحه جزئیات استقرار، آدرس اینترنتی (URL) کامپوننت frontend را مشاهده خواهید کرد. آن آدرس اینترنتی را کپی کرده و در مرورگر خود جایگذاری کنید. مطمئن شوید که از http استفاده میکنید و نه https . همچنین هرگونه هشداری را که ممکن است در مرورگر دریافت کنید، زیرا frontend از http استفاده میکند، بپذیرید.
با برنامه چت کنید و از آن بخواهید که یک برنامه سفر به لندن ایجاد کند.

۸. هاب برنامه و نظارت بر برنامه
- در کنسول ADC، روی دکمهی «مشاهدهی برنامه در App Hub» در گوشهی بالا سمت راست صفحه کلیک کنید.

- این کار برنامه را در App Hub باز میکند. App Hub یک مکان مرکزی برای مشاهده و مدیریت تمام برنامههای شماست و شما را از دیدگاه منبع محور به دیدگاه برنامه محور منتقل میکند. ایجاد یک برنامه با استفاده از ADC به طور خودکار یک برنامه را در App Hub ایجاد میکند. شما باید تمام حجم کار و سرویسهایی را که برنامه را تشکیل میدهند، در اینجا مشاهده کنید. به جای مشاهده منابع موجود در ابر به عنوان منابع جداگانه، میتوانید آنها را به عنوان بخشی از یک برنامه واحد مشاهده کنید که مدیریت و نظارت را ساده میکند.

- روی دکمهی «مشاهده در مشاهدهپذیری» کلیک کنید. این کار باید برنامه را در کنسول مشاهدهپذیری باز کند.
- نمای داشبورد را باز کنید. داشبورد با ارائه معیارهایی مانند 4 سیگنال طلایی: نرخ درخواست، نرخ خطا، تأخیر و اشباع، نمای کلی از عملکرد و سلامت برنامه را به شما ارائه میدهد. این نظارت متمرکز بر برنامه برای حفظ قابلیت اطمینان بسیار مهم است. همچنین میتوانید گزارشها و ردیابیهای برنامه را مشاهده کنید که به شما امکان میدهد سیگنالها را با هم مرتبط کرده و گلوگاهها را مشخص کنید. این امر به ویژه در یک برنامه پیچیده عاملمحور مانند این مهم است، جایی که پاسخهای کند از Vertex AI یا سرور Data MCP میتواند تجربه کاربر را خراب کند.

- کاوش هدایتشده : از عامل یک سؤال خاص در برنامه بپرسید (مثلاً "بهترین مکانها برای بازدید در لندن کدامند؟"). سپس، به کنسول Observability برگردید و لیست Traces را مشاهده کنید. trace مربوط به درخواست خود را پیدا کنید. برای مشاهده نمای آبشاری دقیق، روی آن کلیک کنید. توجه کنید که چگونه میتوانید زمان صرف شده در frontend، backend عامل و تماسها با Vertex AI را مشاهده کنید. این به شما امکان میدهد دقیقاً مشخص کنید که تأخیر در کجا ایجاد میشود.
۹. تبریک
تبریک! شما یک معماری برنامه سه لایه را با استفاده از ADC مستقر کردهاید.
آنچه آموختهاید
- چگونه با استفاده از ADC یک معماری ابری را به صورت بصری مونتاژ کنیم.
- نحوه تنظیم ADC و فعال کردن APIها از طریق رابط کاربری.
- نحوه استقرار برنامهها با استفاده از ADC
- نحوه استفاده از App Hub برای مشاهده منابع خود با محوریت برنامه.
- نحوه نظارت بر سلامت برنامه با استفاده از داشبورد مشاهدهپذیری.