طراحی معماری میکروسرویس با الگوی SAGA

طراحی معماری میکروسرویس با الگوی SAGA

نوشته شده توسط: تیم فنی نیک آموز
تاریخ انتشار: ۲۹ مرداد ۱۴۰۱
آخرین بروزرسانی: 23 دی 1403
زمان مطالعه: 10 دقیقه
۳.۴
(۷)

مقدمه

میکروسرویس‌ها به‌ عنوان روش مناسبی برای مقیاس‌بندی و نگهداری هرچه ساده‌تر برنامه‌ها شناخته می‌شوند. با این ‌حال، این روش نیز دارای جنبه‌های مثبت و منفی خاص خود است. در برنامه‌های کاربردی یکپارچه معمولاً از تراکنش‌های پایگاه ‌داده با ویژگی‌های ACID استفاده می‌شود که سازگاری داده‌ها را تسهیل می‌کند. بااین‌وجود، اگر در تراکنش پایگاه ‌داده ما چندین میکروسرویس پخش شده باشد، چگونه می‌توانیم از سازگاری داده‌ها اطمینان حاصل کنیم؟ پاسخ ساده است: با الگوی saga. در ادامه به موضوع طراحی معماری میکروسرویس با الگوی saga میپردازیم.

آشنایی با طراحی معماری میکروسرویس با الگوی saga

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

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

این درخواست‌های اضافی به‌ عنوان تراکنش‌های جبرانی شناخته می‌شوند و همه این موارد می‌توانند به این معنا باشند که استفاده از الگوهای saga قابلیت پیچیده‌سازی برنامه‌ها را دارند.

راهکارهای پیاده ‌سازی SAGA

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

 استفاده از روش Orchestration (متمرکز)

در این روش یک هماهنگ‌کننده مرکزی وجود دارد که مسئول فراخوانی خدمات از راه دور برای استفاده از الگوی saga است.

استفاده از روش Choreography (توزیع شده)

در این روش هیچ‌گونه هماهنگ‌کننده مرکزی وجود ندارد و به همین دلیل، هر سرویس باید گوش‌به‌زنگ باشد و رویدادها را تولید کند. همچنین سرویس‌ها باید در خصوص اقداماتی که نیاز به اجرا شدن دارند، تصمیم‌گیری کنند.

در ادامه جزئیات بیشتری درخصوص این دو راه پیاده‌ سازی saga ارائه خواهیم کرد.

استفاده از روش Orchestration (متمرکز):

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

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

استفاده از روش Choreography (توزیع شده)

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

استفاده از روش Choreography زمانی بهترین نتیجه را خواهد داشت که تیم‌های بیشتری درگیر مدیریت saga باشند. از مزایای این روش می‌توان به این نکته اشاره کرد که هر تیم به ‌صورت اختصاصی بر روی sagaهای موجود در محدوده خود متمرکز خواهد بود. از سوی دیگر، به دلیل نبود هیچ هماهنگ‌کننده مرکزی نیازی به یک میکروسرویس جداگانه که مسئول هماهنگی یک گردش کار باشد، نیست.

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

 

 

سایر نکات مربوط به الگوی SAGA

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

شناسه تراکنش جهانی

شناسه تراکنش جهانی می‌تواند به نظارت یا اشکال‌زدایی کمک کند و به کمک آن می‌توانیم بدانیم که کدام تراکنش شکست‌خورده است و اقدامات مناسب را برای رفع آن انجام دهیم.

قفل‌های معنایی

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

بازگرداندن پاسخ‌ها

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

دوره آموزش معماری میکروسرویس نیک آموز

نتیجه‌گیری طراحی معماری میکروسرویس با الگوی saga

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

چه رتبه ای می‌دهید؟

میانگین ۳.۴ / ۵. از مجموع ۷

اولین نفر باش

title sign
معرفی نویسنده
تیم فنی نیک آموز
مقالات
401 مقاله توسط این نویسنده
محصولات
0 دوره توسط این نویسنده
تیم فنی نیک آموز
title sign
دیدگاه کاربران

close-image