ویرگول
ورودثبت نام
ماهرخ شاه صفی
ماهرخ شاه صفی
ماهرخ شاه صفی
ماهرخ شاه صفی
خواندن ۳ دقیقه·۱ روز پیش

چرا نباید برای سیستم سه سال آینده معماری بسازیم؟

عنوان سخنرانی: Master Software Architecture: From Simplicity to Complexity Maciej «MJ» Jedrzejewski GOTO 2025

سخنران: Maciej «MJ» Jedrzejewski - Tech Agnostic Architect & Author of “Master Software Architecture”

ویدیو: با همین "عنوان سخنرانی" در یوتوب تماشا کنید.

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

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

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

تله میان‌برهای شناختی و سندروم FOMO

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

پادزهر معماری‌های تحمیلی

پایه‌ی هر تصمیم معماری درست، فهم عمیق Business Domain است. روش‌های سنتی مستندسازی نیازمندی‌ها به دلیل خطی بودن، توانایی انتقال جزئیات پیچیده، استثناها و تضاد منافع ذینفعان را ندارند. در مقابل، ابزارهایی مانند Event Storming با تمرکز بر رویدادهای واقعی بیزینس به عنوان فکت‌های غیرقابل تغییر و Domain Storytelling به معماران کمک می‌کنند تا با زبان مشترک، مرزهای سیستم یا همان Bounded Contextها را به درستی ترسیم کنند. نقشه متنی حاصل از این تعاملات، روابط بین دامنه‌ها را به صورت شفاف به تصویر می‌کشد و مانع از مبارزه همیشگی تیم فنی با ساختار نرم‌افزار می‌شود.

چهار گام تکامل ساختار نرم‌افزار

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

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

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

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

  4. پیچیدگی: با ورود قوانین جدید و تغییرات بنیادین بیزینس، مدل‌های ساده دیگر پاسخگو نیستند. در این فاز، معماران با به کارگیری مفاهیم پیشرفته Domain-Driven Design مانند Aggregateها، مدیریت انسجام داده‌ها را بر عهده می‌گیرند.

نتیجه گیری

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

منابع:

  • Evolution of Software Architecture: Nav Dhunay

  • Domain-Driven Design: Martin Fowler

  • Skelton, M., & Pais, M. (2019)Team Topologies: Organizing Business and Technology Teams for Fast Flow

«اين مطلب، بخشی از تمرينهای درس معماری نرم‌افزار در دانشگاه شهيدبهشتی است»

#معماری_نرم_افزار_بهشتی

معماری نرم‌افزارتیم فنی
۰
۰
ماهرخ شاه صفی
ماهرخ شاه صفی
شاید از این پست‌ها خوشتان بیاید