فاطمه میرزایی
فاطمه میرزایی
خواندن ۲۰ دقیقه·۱ سال پیش

Assignment#01 درس معماری نرم افزار

Modular Monolithic

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

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

الگوی ماژولار مونولیتیک می‌تونه گزینه مناسبی برای سازمان‌هایی باشه که نمی‌توانند یا نمی‌خواهند به میکروسرویس‌ها تغییر بدن. این روش به آن‌ها کمک می‌کنه که یک سطح استقلال رو حفظ کنن، که در صورت نیاز به راه‌اندازی میکروسرویس‌ها مفید باشه.

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

****

AWS

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

AWS دارای یه انجمن بزرگ از مشتریان و شرکای تجاریه که شامل میلیون‌ها کاربر فعال و ده‌ها هزار شرکت مشاوره و نرم‌افزاری میشه. این انجمن بهت کمک میکنه تا از تجربه، دانش و ابتکارات دیگران بهره ببری و راه‌حل‌های مناسب برای نیازات پیدا کنی.

AWS همچنین سرعت بالایی در نوآوری داره و به طور مداوم خدمات و ویژگی‌های جدیدی رو ارائه میده. برای مثال، AWS در سال 2014 مفهوم برنامه‌نویسی بدون سرور رو با راه‌اندازی AWS Lambda معرفی کرد. همچنین با ساخت Amazon SageMaker، یک سرویس یادگیری ماشین کاملاً مدیریت شده رو فراهم کرد.

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

AWS دسته‌بندی‌های اصلی محصولات خود را در زیر بیان کرده است:

1. محاسبات: Elastic Compute Cloud (EC2)

2. ذخیره‌سازی: Simple Storage Service (S3)

3. مدیریت داده: Amazon RDS, DynamoDB, Redshift

4. شبکه: Virtual Private Cloud (VPC), Route 53

علاوه بر این، AWS به شما امکان میده تا از ارتباط مستقیم بین cloud AWS و مرکز داده on-site استفاده کنید. همچنین، با سرویس‌ها و ابزارهای مختلف، AWS به شما کمک میکنه تا داده‌هات، پایگاه‌های دادت و برنامه‌ات رو به cloud منتقل کنید. AWS همچنین ابزارهای مانیتورینگ و مدیریت رو فراهم کرده تا به تیم‌های IT کمک کنه که سرویس‌های cloud خود رو بهینه‌سازی کنن.

****

API-first Approach

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

توی دنیای نرم‌افزار، مردم از APIها برای چیزهای مختلف استفاده می‌کنن. مثلاً وقتی برنامه‌نویسا می‌خوان از ویژگی‌های یه زبان برنامه‌نویسی خاص استفاده کنن، از API زبان اون استفاده می‌کنن. یا وقتی می‌خوان از کد‌های آماده در کتابخانه‌های نرم‌افزاری استفاده کنن، از API کتابخونه استفاده می‌کنن.

روش API-first Approach یعنی اولین اولویت طراحی و توسعه API است. به این معنی که قبل از هر چیزی، خود API طراحی و ساخته می‌شه. این باعث میشه که برنامه‌ها بتونن به راحتی با هم ارتباط برقرار کنن و از APIهای دیگه که ارائه شده، استفاده کنن. روش API-first Approach مزایای زیادی داره. برای مثال، باعث میشه که تیم‌های توسعه بتونن به صورت موازی و مستقل روی APIهای مختلف کار کنن. این کمک می‌کنه که APIها قبل از نوشته شدن کد، آزمایش بشن. این روش همچنین باعث میشه که هزینه‌های توسعه کمتر بشه و بیشتر مشکلات قبل از نوشتن کد حل بشن.

در این روش، API به صورت مرحله به مرحله طراحی و ارتقا می‌پذیره:

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

• آزمایش API : بعد از تعریف API، باید اون رو آزمایش کرد. این کار به تیم‌ها کمک می‌کنه تا مطمئن بشن که API عملکرد درستی داره و با سایر APIها سازگاره.

• مستندسازی API : API باید به شکل شفافی برای کاربران و توسعه‌دهندگان مستند شود. مستندسازی که شامل هدف، نحوه استفاده، محدودیت‌ها و نمونه‌های کد است، باعث می‌شه استفاده از API برای بقیه راحت‌تر باشه.

• انتشار API : بعد از اطمینان از کارکرد صحیح API و مستندسازی، مرحله بعدی انتشارشه. API به صورت عمومی یا خصوصی منتشر می‌شه تا بقیه بتونن ازش استفاده کنن.

• بهبود API : این مرحله همیشه در جریانه! API بر اساس بازخورد کاربران و توسعه‌دهندگان بهبود می‌بینه. افزودن ویژگی‌های جدید، رفع اشکالات و بهبود عملکرد و امنیت API از جمله تغییراتی هستن که ممکنه در این مرحله صورت بگیره.

این روش باعث میشه که از ابتدا تا انتها، توسعه براساس API طراحی بشه و این امکان رو می‌ده که برنامه‌ها و خدمات مختلف با هم ارتباط داشته باشن و از هم استفاده کنن.

****

NoSQL Databases

NoSQL یا پایگاه داده‌های غیر رابطه‌ای که از ساختارهای دیگر به جای جداول برای ذخیره و پرس‌وجوی داده‌ها استفاده می‌کنند. این نوع پایگاه داده‌ها، به جای استفاده از ساختارهای جدولی مانند پایگاه‌های داده رابطه‌ای یا SQL، از ساختارهایی مانند اسناد، کلید-مقدار، ستونی یا گرافی برای ذخیره اطلاعات استفاده می‌کنند. دلایل استفاده از NoSQL برای شرکت‌ها می‌تونه مختلف باشه: مثلاً برای مقیاس‌پذیری بیشتر و توزیع داده‌ها روی چندین سرور، انعطاف‌پذیری در ساختار داده‌ها، یا سرعت بالا در ذخیره و پرس و جو کردن داده‌ها.مراحل طراحی و توسعه پایگاه داده NoSQL هم ممکنه بر اساس نیازهای هر پروژه متفاوت باشن. مثلاً باید مدل داده و ساختار داده‌ای که می‌خوایم استفاده کنیم رو انتخاب کنیم، سپس پایگاه داده رو ایجاد و پیکربندی کنیم و بعدش آزمایش و مستندسازیش کنیم. در نهایت هم می‌تونیم اون رو منتشر کنیم تا بقیه بتونن استفاده کنن.

****

Serverless Architecture

یک روش برنامه‌نویسی ت ابریه که به برنامه‌نویسا این اجازه رو می‌ده که بدون دغدغه‌ی مدیریت سرور، برنامه‌هاشون رو بنویسن و اجرا کنن. تو این روش، ابر کامپیوتری مسئولیت سرورها و دیتابیس‌ها رو برای اجرای برنامه‌ها به عهده می‌گیره. برنامه‌نویسا می‌تونن کدهاشون رو در قالب قطعه‌های کوچیک (کانتینر) بنویسن و اجرا کنن. برنامه‌ها بصورت خودکار وقتی نیاز باشه، می‌شن وقتی نیاز نباشه، خاموش می‌شن.

Serverless Architecture چند نوع مختلف داره که از نظر اجراشون فرق می‌کنن. دو نوع مهمشون:

• Backend-as-a-Service (BaaS): که به برنامه‌نویسا امکان می‌دهد از سرویس‌هایی که توسط ابر کامپیوتر ارائه می‌شه، استفاده کنن. مثلا سرویس‌های احراز هویت، پیام‌رسانی، و غیره. اینجور سرویس‌ها به برنامه‌نویسا کمک می‌کنن که بدون نوشتن کد زیاد، بخش‌هایی از برنامه‌هاشون رو ایجاد کنن.

• Function-as-a-Service (FaaS): که به برنامه‌نویسا این اجازه رو می‌ده که توابع مختلفی رو بنویسن و استقرار بدن. هر تابع وقتی نیاز باشه، اجرا می‌شه برای وقایع خاص مثل یه درخواست اینترنتی. تامین‌کننده ابر کامپیوتری مسئول اجرای توابع هست و منابع مورد نیاز رو بهشون می‌ده.

Serverless Architecture مزایا و معایبی داره که بسته به نوع پروژه، ممکنه تغییر کنن. برخی مزایایش:

• کاهش هزینه: به برنامه‌نویسا اجازه می‌ده که فقط وقتی که برنامه‌هاشون در حال اجرا هستن، پرداخت کنن. این باعث کاهش هزینه‌های مربوط به مدیریت سرورها می‌شه.

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

• افزایش مقیاس‌پذیری: برنامه‌ها به صورت خودکار وقتی که نیاز باشه، می‌تونن مقیاس‌پذیر باشن و این باعث افزایش قابلیت دسترسی و عملکرد برنامه‌ها می‌شه.


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

****

Domain Driven Design

Domain Driven Design یا DDD یک روش طراحی نرم افزاره که باهاش می‌تونی نحوه‌ی ساختار داده‌ها و زبان کدت رو با دامنه کاری که بهش مربوطه هماهنگ کنی. این دامنه مربوط به موضوع یا کاری هست که نرم افزارت براش ساخته شده.

به عنوان مثال، اگه نرم افزارت درخواست وام‌ها رو پردازش می‌کنه، ممکنه کلاس‌ها و متدهایی مثل "درخواست وام"، "مشتریان" و "پذیرش پیشنهاد" و "انصراف" داشته باشه. در DDD، یه مدل دامنه می‌سازی که یه سیستم از مفاهیم مهم دامنه رو توصیف می‌کنه و می‌تونه بهت کمک کنه مشکلات مربوط به اون دامنه رو حل کنی.

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

از مثال‌هایی مثل پروژه library در GitHub (https://github.com/ddd-by-examples/library)می‌شه استفاده کرد که یه نمونه خوب از اجزای مختلف DDD رو نشون می‌ده.

DDD مزایای زیادی داره مثل ارتباط بهتر بین افراد، انعطاف‌پذیری بیشتر در مقابل تغییرات، و قابلیت نگهداری بهتر. اما همراه با این مزایا، معایبی مثل پیچیدگی بالا، هزینه بیشتر و محدودیت در استفاده در برخی پروژه‌ها هم داره.

****

Hexagonal Architecture

معماری هگزاگونال یا Hexagonal Architecture، یک الگوی طراحی نرم‌افزاره که می‌خواد قسمت مهم و اصلی نرم‌افزار (همون قلبش) رو از چیزای خارجی جدا کنه. تو این الگو، ورودی‌ها و خروجی‌ها در کنارهای طراحی قرار می‌گیرن و با استفاده از درگاه‌ها و مبدل‌ها با بیرون نرم‌افزار ارتباط برقرار می‌کنن. این کار باعث می‌شه اجزای نرم‌افزار، قابل تعویض و آزمون بشن.

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


این معماری یه گام جلوتر از معماری لایه‌ای هست. در این الگو، حتی می‌تونی رابط کاربری رو هم عوض کنی. این الگو توسط آلیستر کاکبرن در سال ۲۰۰۵ معرفی شده. اصلی‌ترین ایده اون از کتاب Object Design: Roles, Responsibilities, and Collaborations برداشته شده. در این کتاب، نویسندگان به درگاه‌ها و مبدل‌ها به عنوانInterfacers اشاره کردن که نقش ارتباط اجزای نرم‌افزار رو نشون میدن.

تو معماری هگزاگونال، سیستمت رو به چند قسمت کوچیک تقسیم می‌کنی که می‌شه جایگزین‌شون کرد و ارتباطشون کمه. مثلاً هسته نرم‌افزار، پایگاه داده، رابط کاربری و اجزای تست. این الگو یه جایگزین برای معماری لایه‌ای هست. هر قسمت از طریق چندین درگاه قابل دسترسیه. این درگاه‌ها و پروتکل‌ها یه رابطی انتزاعی تعریف می‌کنن که می‌شه با هر روش مناسبی (مثلاً فراخوانی متد، فراخوانی رویه از راه دور و یا وب سرویس) پیاده‌سازیشون کرد.

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

یک مقاله با نام Hexagonal architecture tutorial: Build maintainable web apps وجود داره که بهت یاد می‌ده چطور یه وب اپلیکیشن با استفاده از معماری هگزاگونال و زبان پایتون بسازی. تو این مقاله نحوه تعریف درگاه‌ها، مبدل‌ها و مدل دامنه رو نشون میده.

****

Event Sourcing

یک روش ثبت تغییرات در داده‌های یک کسب و کار است. به جای اینکه تنها وضعیت فعلی داده‌ها را نگه دارد، هر تغییر در داده‌ها به عنوان یک رویداد ثبت می‌شود. مانند یک لیست که هر عملیاتی را ذخیره می‌کند. این رویدادها نشان‌دهنده تغییراتی در داده‌ها هستند، مثلاً افزودن یک مورد به یک سفارش. این رویدادها در یک مکان مخصوص ذخیره می‌شوند که به عنوان سیستم ثبت رسمی عمل می‌کند و می‌توان از آن برای مدیریت وضعیت فعلی داده‌ها استفاده کرد.

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

Event Sourcing چندین مزیت داره:

- تاریخچه: می‌تونیم لاگ تمام تغییرات رو ببینیم و چگونگی رسیدن به وضعیت فعلی رو بفهمیم.

- قابلیت بازگشت: می‌تونیم وضعیت گذشته رو بازسازی کنیم.

- قابلیت تغییر: می‌تونیم تغییرات رو به صورت retroactive اعمال کنیم.

البته این روش هم معایبی داره:

- پیچیدگی: پیاده‌سازی Event Sourcing نیازمند تجربه و همکاری با کارشناسان دامنه و ایجاد یک زبان مشترکه.

- هزینه: پیاده‌سازی و نگهداری این روش هزینه‌بره.

این روش می‌تونه با هر زبان برنامه‌نویسی استفاده بشه، اما برخی از زبان‌ها ابزارهای مناسبتری برای این کار دارن. برخی از زبان‌های معمول برای استفاده از Event Sourcing:

- جاوا اسکریپت: استفاده زیادی در توسعه وب داره و ابزارهای زیادی برایش ارائه شده مثل Node.js و React.

- پایتون: به خاطر سادگی و خواناتیش خوبه و کتابخانه‌هایی مثل EventSourcing .

****

Low code platforms

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

بعضی از مزایای استفاده از پلتفرم‌های کم کد عبارتند از:

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

• قابلیت تغییر و سفارشی‌سازی برنامه‌ها بر اساس نیازها و ترجیحات کاربران، بدون افت کیفیت یا عملکرد برنامه.

• افزایش همکاری و نوآوری از طریق به اشتراک‌گذاری و دوباره استفاده از برنامه‌ها و سیستم‌های مختلف.

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

همچنین، برخی از چالش‌هایی که پلتفرم‌های کم کد دارند:

• محدودیت‌هایی در اموری مانند مقیاس‌پذیری، عملکرد، امنیت و یکپارچگی، به خصوص برای برنامه‌های پیچیده یا در مقیاس بزرگ.

• نیاز به مهارت‌های کدنویسی یا فنی برای ویژگی‌های پیشرفته یا سفارشی‌سازی، بسته به پلتفرم و نیازهای برنامه.

• خطراتی مانند قطع پشتیبانی یا تغییرات ارائه‌دهنده پلتفرم ممکن است به مسائل انطباق یا از دست دادن داده‌ها منجر شود.

چند نمونه از پلتفرم‌های کم کد عبارتند از:

• Creatio: یک پلتفرم کم کد برای ایجاد برنامه‌های مدیریت فرآیند کسب و کار و مدیریت ارتباط با مشتری با ویژگی‌های طراحی ساده، ویژگی‌های کشیدن و رها کردن و اتوماسیون.

‌ Microsoft Power Apps: یک پلتفرم با کد کم برای ساخت برنامه‌های وب و موبایل با قابلیت‌های اتصال دهنده‌های داده، الگوهای آماده و استفاده از سرویس‌های ابری.

• Google AppSheet: یک پلتفرم کم کد برای ایجاد برنامه‌های مبتنی بر داده‌های مختلف با قابلیت‌های مثل پردازش زبان طبیعی و یادگیری ماشینی.

• Salesforce Platform: یک پلتفرم کم کد برای ساخت برنامه‌های اکوسیستم Salesforce با ویژگی‌هایی مانند اجزای Lightning و ادغام با AppExchange و Heroku."

****

سیستم‌های مدیریت فرآیند کسب و کار (BPMS) ابزارهای نرم‌افزاری هستن که به شما کمک می‌کنند فعالیت‌های مختلفی که برای دستیابی به هدفی خاص انجام می‌شه (مثلاً ساخت محصول یا ارائه خدمات به مشتری) رو طراحی، اجرا، نظارت و بهینه‌سازی کنید. این ابزارها می‌تونن به شما کمک کنن فرآیندهای کاری رو خودکارتر، ساده‌تر و بهتر انجام بدین و اونها رو کارآمدتر، مؤثرتر و سازگارتر کنین.

بعضی ویژگی‌ها و مزایای BPMS:

• به شما اجازه می‌ده که از ابزارهای گرافیکی مثل نمودارها و فلوچارت‌ها استفاده کنید و فرآیندهای کاری‌تون رو مدل کنید. می‌تونید مراحل، نقش‌ها، قوانین، داده‌ها و منابع مورد استفاده در هر فرآیند رو تعریف کنید.

‌ شما رو قادر می‌سازند که فرآیندهای کاری‌تون رو با استفاده از فناوری‌های مختلف مثل وب سرویس‌ها، پایگاه داده‌ها و برنامه‌های کاربردی اجرا کنید و با سیستم‌ها و پلتفرم‌های مختلف ادغامشون کنید.

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

• این ابزارها به شما امکان می‌دهند که با اعمال تغییرات یا نوآوری‌ها، فرآیندهای کاری‌تون رو بهبود ببخشید. می‌تونید به سرعت و آسونی تغییرات رو آزمایش و اعمال کنید و با تغییر نیازهای کسب‌وکار، انتظارات مشتریان یا شرایط بازار سازگارشون کنید.

چند نمونه از BPMS:

• Creatio: یک BPMS که به شما امکان می‌دهد برنامه‌های مدیریت فرآیند کسب‌وکار و مدیریت ارتباط با مشتری رو با ویژگی‌های مدل‌سازی بصری و اتوماسیون مبتنی بر هوش مصنوعی ایجاد کنید.

• Microsoft Power Automate: یک BPMS بر پایه ابر که به شما اجازه می‌دهد گردش‌کارها و وظایف رو در برنامه‌ها و سرویس‌های مختلف اجرا کنید.

• Oracle BPM Suite: یک BPMS سازمانی که به شما امکان می‌دهد فرآیندهای کاری‌تون رو مدیریت و بهینه‌سازی کنید.

****

Message Queue (such as Kafka and RabbitMQ)

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

بعضی مزایای استفاده از MQ:

• کاهش وابستگی بین برنامه‌ها؛ چون MQ به برنامه‌ها اجازه میده بدون اطلاعات دقیق در مورد هم، مثل مکان یا فرمت، کار کنن. این باعث میشه برنامه‌ها انعطاف‌پذیرتر و مواجه با تغییرات سازگارتر باشن.

• بهبود عملکرد برنامه‌ها؛ چون می‌تونند پیام‌ها رو بدون مسدود شدن یا منتظر موندن ارسال و دریافت کنن. همچنین MQ کار رو بین چند برنامه توزیع می‌کنه و از مشکلات و خرابی‌ها جلوگیری می‌کنه.

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

چند نمونه از سیستم پیام‌رسانی:

• کافکا: یک پلتفرم پخش توزیع‌شده که به برنامه‌ها امکان میده جریان پیام‌ها رو منتشر کنن و با هم به اشتراک بذارن. کافکا بهترین ویژگی‌های یک سیستم پیام‌رسانی رو داره، مانند پردازش داده، تکرار، و یکپارچه‌سازی.

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

****

Container orchestration (such as Kubernetes)

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

مزایای استفاده از Container orchestration:

س کارایی: ارکستراسیون کانتینر منابع رو بهینه کنه و هزینه های عملیاتی رو کم می‌کنه. همچنین بهترین شکل استقرار و به‌روزرسانی برنامه‌ها رو فراهم می‌کنه.

• مقیاس پذیری: این روش به شما این امکان رو میده که برنامه هاتون رو بر اساس نیازتون تغییر سایز بدین. همچنین با توزیع ترافیک و قرار دادن سرویس‌ها در سراسر شبکه، از برخی مشکلات هم جلوگیری می‌کنه.

• قابلیت اطمینان: مطمئن میشید که برنامه هاتون همیشه در دسترس و مقاوم در برابر خطا هستن. این روش ویژگی‌هایی مثل بررسی سلامت و برگشت به حالت پیشین رو داره که در مواقع ناخواسته، کمک می‌کنه مشکلات رو حل کنید.

چند نمونه ابزار Container orchestration:

• Kubernetes: این ابزار به شما کمک می‌کنه تا مجموعه‌ای از کانتینرها رو با استفاده از مفاهیمی مثل پادها، سرویس‌ها و گره‌ها مدیریت کنید. Kubernetes از ویژگی‌های زیادی مثل زمان‌بندی، شبکه‌سازی و امنیت پشتیبانی می‌کنه.

• Docker Swarm: این ابزار از مفاهیمی مثل سرویس‌ها و گره‌ها استفاده می‌کنه تا مجموعه‌ای از گره‌های Docker رو مدیریت کنه. Docker Swarm از ویژگی‌هایی مثل کشف سرویس و متعادل‌سازی بار پشتیبانی می‌کنه.

• Apache Mesos: این ابزار یه سیستم توزیع شده است که به شما کمک می‌کنه که کانتینرها و بارهای کاری دیگه رو هماهنگ کنید. Apache Mesos از ویژگی‌هایی مثل تخصیص منابع و تحمل خطا پشتیبانی می‌کنه.

****

Log Management Tools (such as ELK)

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

ELK Stack یه از معروف‌ترین ابزارهای این دسته‌ست. این پشته شامل Elasticsearch، Logstash و Kibana هست. Elasticsearch یه موتور جستجو و تجزیه و تحلیله، Logstash داده‌ها رو جمع‌آوری و ارسال می‌کنه و Kibana اون داده‌ها رو به صورت نمودار یا گزارش نشون می‌ده.

ELK Stack بهتون کمک می‌کنه داده‌های گزارش رو جمع‌آوری کنید و ببینید چه اتفاقاتی تو برنامه‌هاتون میوفته. به علاوه، با این ابزار می‌تونید داده‌ها رو از منابع مختلف جمع‌آوری کنید و به شکل نمودارهایی روشن و زیبا نشون بدید.

اگه به دنبال جایگزینی برای ELK هستید، می‌تونید Sematext Logs رو امتحان کنید. این ابزار مدیریت Log هست که داده‌هاتون رو جمع‌آوری و نمایش می‌ده، بدون اینکه نیاز به مدیریت پیچیده‌ترین قسمت‌های ELK باشه. Sematext Logs همچنین ویژگی‌های امنیتی و نظارتی خوبی داره که ممکنه مورد نیازتون باشه.

****

Monitoring tools (such as Prometheus)

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

یکی از ابزارهای محبوب برای نظارت، Prometheus هست. این ابزار کمک می‌کنه تا داده‌های مربوط به عملکرد برنامه‌هاتون رو جمع‌آوری کنید و اطلاعات مهمی رو نشون بدید. با استفاده از این ابزار، می‌تونید:

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

• معیارهای مهمی رو ذخیره و نمایش بدید و هشدار بگیرید.

• اعلان‌ها رو به کانال‌های مختلف ارسال کنید.

• از ابزارهایی مثل Grafana برای ساخت داشبورد و نمودارهایی استفاده کنید که بهتون کمک کنه معیارهای Prometheus رو بهتر بفهمید.

****

Static Code Analysis (such as SonarQube)

"تجزیه و تحلیل کد استاتیک (SCA) یعنی چک کردن کدهای یک نرم‌افزار که نوشته شده و برای پیدا کردن و رفع اشکالات، مشکلات و نقاط ضعفشون هست. SCA با استفاده از قوانین و استانداردها کمک می‌کنه تا کیفیت و امنیت نرم‌افزار بهتر بشه.

بعضی مزایای SCA اینجوری هستن:

• می‌تونه مشکلاتی که ممکنه وقتی نرم‌افزار اجرا میشه پیش بیان و جلوگیریشون کرده.

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

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

اما چند مشکل هم داره:

• ممکنه گزارشات اشتباهی رو بده که مشکلات حقیقی نیستن یا مشکلات واقعی رو نادیده بگیره.

• پیکربندی و سفارشی کردن ابزارها و گزارشات بسته به نوع پروژه و زبان‌های برنامه‌نویسی ممکنه زمان‌بر باشه.

• پوشش دادن همه جنبه‌های کدها مثل ورودی‌های کاربر یا رفتارهای مختلف ممکنه دشوار باشه.

SonarQube یکی از ابزارهای معروف برای SCA هست. این ابزار کدهای نوشته شده به زبان‌های مختلف رو چک می‌کنه و گزارش‌هایی در مورد کیفیت کد، تست‌ها، باگ‌ها و آسیب‌پذیری‌های امنیتی می‌ده. همچنین از ویژگی‌هایی مثل داشبورد و هشدارها برای اطلاعات بیشتر و ادغام با ابزارهای دیگه هم پشتیبانی می‌کنه.




منابع:

https://www.mongodb.com/nosql-explained

https://www.g2.com/articles/serverless-architecture

https://www.redhat.com/en/topics/cloud-native-apps/what-is-serverless

https://www.datadoghq.com/knowledge-center/serverless-architecture/

https://domaindrivendesign.org/ddd-domain-driven-design/

https://en.wikipedia.org/wiki/Domain-driven_design

https://dzone.com/articles/hexagonal-architecture-what-is-it-and-how-does-it

https://martinfowler.com/eaaDev/EventSourcing.html

https://powerapps.microsoft.com/en-us/low-code-platform/

https://www.g2.com/categories/low-code-development-platforms

https://www.processmaker.com/blog/what-is-a-bpms-a-guide-to-business-process-management-systems/

https://aws.amazon.com/compare/the-difference-between-rabbitmq-and-kafka/

https://medium.com/@ramekris/message-queues-rabbitmq-vs-kafka-335076a5ff88

https://sematext.com/blog/best-log-management-tools/

https://en.wikipedia.org/wiki/Prometheus_(software)









معماری نرم افزارModular MonolithicawsapiNoSQL Databases
شاید از این پست‌ها خوشتان بیاید