آرمان تاکستانی
آرمان تاکستانی
خواندن ۹ دقیقه·۱ سال پیش

توضیحات کوتاهی در رابطه با مفاهیمی از معماری نرم افزار

Modular Monolithic

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

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

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


AWS

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

API-first Approach

رویکرد API-first Approach یک الگوی طراحی نرم‌افزار است که در آن توسعه‌دهندگان از ابتدا با طراحی و توسعه واسط‌های برنامه‌نویسی (API) شروع به کار می‌کنند. این الگو تفاوت قابل توجهی با رویکردهای سنتی دارد که در طراحی نرم‌افزار از طریق واسط‌های کاربری (UI) یا دیگر جزئیات فنی آغاز می‌شوند.

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

  1. انعطاف‌پذیری: توسعه از طریق APIها امکان تغییرات در سیستم را بدون تأثیر بر سایر اجزا وابسته به کاهش حداقلی می‌دهد.
  2. توسعه موازی: تیم‌ها می‌توانند به صورت موازی بر روی قسمت‌های مختلف APIها کار کنند و بدون انتظار برای دیگر تیم‌ها پیش‌روی خود را بگیرند.
  3. تست‌پذیری: از آنجایی که تعاملات بین اجزاء از طریق APIها انجام می‌شود، تست و اعتبارسنجی آنها به صورت مستقل امکان‌پذیر می‌شود.
  4. مستندسازی بهتر: با اولویت‌دهی به طراحی APIها، مستندسازی بهتری از تعاملات سیستم ایجاد می‌شود که به توسعه‌دهندگان و مصرف‌کنندگان API کمک می‌کند.
  5. استفاده مجدد: طراحی APIهای قوی و مستقل از پیاده‌سازی جزئیات داخلی امکان استفاده مجدد از آنها در پروژه‌های مختلف را فراهم می‌کند.
NoSQL Databases

پایگاه‌داده‌های NoSQL سیستم‌های ذخیره‌سازی داده هستند که از مدل‌ها و ساختارهای غیررابطه‌ای برای ذخیره اطلاعات استفاده می‌کنند. این پایگاه‌داده‌ها عمدتاً برای مقیاس‌پذیری بالا و پردازش داده‌های نیمه‌ساختاری یا غیرساختاری مورد استفاده قرار می‌گیرند. مثالهایی از آنها شامل MongoDB و Cassandra می‌شوند.

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

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

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

انواع مختلف دیتابیس NoSQL
انواع مختلف دیتابیس NoSQL


Serverless Architecture

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

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

معماری بدون سرور به توسعه‌دهندگان این امکان را می‌دهد تا تمرکز خود را بر روی توسعه کد و ویژگی‌های کسب‌وکار بیشتر کنند و نگرانی‌های مربوط به مدیریت سرورها و زیرساخت را کاهش دهند.

Domain Driven Design

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

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

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

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

در مجموع، DDD یک الگوی طراحی جامع است که با تأکید بر هماهنگی بین توسعه‌دهندگان و اعضای تیم کسب‌وکار، به طراحی سیستم‌های پیچیده و مبتنی بر تجارت کمک می‌کند. این الگو از اصولی همچون تمرکز بر مدل و زبان یکپارچه برای ارتقاء کیفیت و قابلیت درک سیستم استفاده می‌کند.

Hexagonal Architecture

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

Event Sourcing

یک الگوی ذخیره و بازیابی داده است که در آن وضعیت سیستم به صورت یک دنباله از رویدادها ثبت می‌شود. هر تغییر در وضعیت به عنوان یک رویداد ذخیره می‌شود و می‌توان به راحتی تاریخچه تغییرات را بازیابی کرد. این الگو به اطمینان و بازتاب در طراحی سیستم کمک می‌کند.

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

Low Code Platforms

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

همچنین از ابزارها و تکنولوژی‌هایی برخوردارند که امکان توسعه سریع و کارآمد را فراهم می‌کنندو این به توسعه‌دهندگان امکان می‌دهد به سرعت به ساخت و تست نمونه‌های اولیه بپردازند.

این پلتفرم‌ها از ابزارها و ویژگی‌های گرافیکی برخوردارند که به کاربران امکان می‌دهند به سادگی بازهم تنظیمات و عملیات مختلف را انجام دهند. این ابزارها معمولاً از کشیدن و رها کردن (drag-and-drop)، پنل‌های تنظیمات و ویژگی‌های دیگر برای ساخت و تنظیم برنامه‌ها استفاده می‌کنند.

Business Process Management Systems

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

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

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

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

Message Queue

صف پیام یک سیستم نرم‌افزاری است که به تبادل پیام بین اجزای یک سیستم کمک می‌کند. این سیستم معمولاً برای مدیریت جریان پیام‌ها و اطمینان از ارسال و دریافت قابلیت استفاده‌پذیری و انعطاف‌پذیری بالا ارائه می‌دهد.

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

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

Container Orchestration

در کنترل محیط‌های مبتنی بر کانتینر مانند Docker، Kubernetes نقش اصلی ایفا می‌کند. این ابزارها به مدیریت و میزبانی کانتینرها، ایجاد و حذف آنها، مدیریت منابع، و ایجاد توازن بار بین آنها کمک می‌کنند.

یکی از ویژگی‌های اصلی Container Orchestration، امکان استقرار خودکار برنامه‌ها و کانتینرها است. این به توسعه‌دهندگان این امکان را می‌دهد که برنامه‌های خود را با یک فرآیند ساده استقرار کنند.

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

Log Management Tools

سیستم‌های مدیریت لاگ مانند ELK (Elasticsearch, Logstash, Kibana) به تجمیع، ذخیره، و نمایش لاگ‌های سیستمی برای مانیتورینگ، تجزیه و تحلیل، و رفع اشکالات استفاده می‌شوند.

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

ابزارهای مدیریت لاگ اغلب امکانات مرتبط با استانداردها و امنیت را فراهم می‌کنند. این امکان به سازمان‌ها کمک می‌کند که در تطابق با نرم‌افزارها و استانداردهای امنیتی نقاط ضعف خود را شناسایی و بهبود دهند.

Monitoring Tools

این ابزارها به توسعه‌دهندگان و مدیران سیستم کمک می‌کنند تا عملکرد و عملیات سیستم‌های خود را نظارت کنند. مثالها شامل Prometheus می‌شود که به مانیتورینگ و هشدارهای مبتنی بر معیارها متمرکز است.

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

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

Static Code Analysis

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

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

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



منابع :

  • https://www.jrebel.com/blog/what-is-a-modular-monolith
  • https://medium.com/design-microservices-architecture-with-patterns/microservices-killer-modular-monolithic-architecture-ac83814f6862
  • https://www.geeksforgeeks.org/types-of-nosql-databases/
  • https://www.novalisadvisors.it/business-process-management/
  • https://www.thoughtworks.com/en-us/insights/blog/microservices/modular-monolith-better-way-build-software
  • https://aws.amazon.com/console/
  • https://www.postman.com/api-first/
  • https://swagger.io/resources/articles/adopting-an-api-first-approach/
  • https://www.softwaretestinghelp.com/low-code-development-platforms/
شهیدبهشتیمعماری نرم افزار
شاید از این پست‌ها خوشتان بیاید