محمدرضا شاقوزی
خواندن ۴ دقیقه·۲ ماه پیش

تحلیل معماری و چالش‌های فنی مکتب‌خونه: از ترکیب MVT/SOA تا مسائل RESTful

تحلیل معماری فنی مکتب‌خونه
تحلیل معماری فنی مکتب‌خونه


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

۱. ترکیب معماری MVT و SOA: تعادل بین پویایی و پیچیدگی

مکتب‌خونه از ترکیب الگوی معماری MVT (Model-View-Template) و معماری سرویس‌گرا (SOA) برای رندرینگ صفحات استفاده می‌کند. در این مدل:

  • MVT مسئول مدیریت منطق نمایش و قالب‌بندی است.
  • SOA سرویس‌های backend را برای تامین داده‌های پویا (مانند اطلاعات کاربران یا دوره‌ها) ارائه می‌دهد.

چالش‌های کلیدی:

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

۲. پیاده‌سازی ناقص SSR: تاثیر منفی بر سئو و عملکرد

با وجود استفاده از Nuxt.js (چارچوبی مبتنی بر Vue برای SSR)، رندرینگ سمت سرور به صورت کامل اجرا نشده است. به عنوان مثال:

  • درخواست‌های تکراری: اطلاعات سرفصل‌ها پس از لود اولیه صفحه، مجدداً از طریق API فراخوانی می‌شوند (شکل ۱). این رفتار نه تنها زمان پاسخگویی را افزایش می‌دهد، بلکه برای خزنده‌های موتورهای جستجو مشکل‌ساز است .
  • خطای ۴۰۴ با تاخیر: در صورت ورود به URL نامعتبر، ابتدا سرویس‌ها فراخوانی شده و پس از یک لودینگ کوتاه، خطا نمایش داده می‌شود (شکل ۲). این رویکرد غیراستاندارد، تجربه کاربری را تحت تاثیر قرار می‌دهد.
لود صفحه با سرعت پایین در حالت 404
لود صفحه با سرعت پایین در حالت 404


راهکار پیشنهادی:

  • پیش‌رندرینگ استاتیک (SSG): استفاده از قابلیت nuxt generate در Nuxt.js برای تولید صفحات استاتیک از پیش رندر شده، که هم سرعت را بهبود می‌بخشد و هم سئو را بهینه می‌کند .
  • کشینگ سرویس‌ها: کاهش تعداد درخواست‌ها با ذخیره‌سازی پاسخ APIها در سمت کلاینت یا سرور.

۳. انحراف از اصول RESTful: استانداردهای دوگانه و خطاهای طراحی

اگرچه سرویس‌های مکتب‌خونه از فرمت JSON استفاده می‌کنند، اما چندین نقض استاندارد REST مشاهده می‌شود:

۳.۱ مدیریت نادرست وضعیت HTTP

  • خطاهای با کد ۲۰۰: در سرویس Login، حتی در صورت عدم احراز هویت موفق، статуس ۲۰۰ برگردانده می‌شود و نوع خطا در فیلد statusقرار می‌گیرد (شکل ۳). این رویکرد با استاندارد REST مغایرت دارد که پیشنهاد می‌کند برای خطاهای سمت کاربر (مانند ورود ناموفق) از کدهای ۴xx (مانند ۴۰۱) استفاده شود.
خطا با وضعیت 200 برگردانده شده است
خطا با وضعیت 200 برگردانده شده است


این در حالی است که سرویس‌ها گوگل مبتنی بر oauth 2.0 وضعیت 401 برای invalid credentials برمی‌گرداند.

راهنمای google
راهنمای google


۳.۲ ناسازگاری در ساختار پاسخ‌ها

  • عدم ثبات در خروجی: در برخی سرویس‌ها، ساختار JSON بسته به موفقیت یا شکست عملیات تغییر می‌کند. مثلاً در سرویس Login، کلیدهای پاسخ در حالت موفق و ناموفق متفاوت هستند (شکل ۴). این موضوع پردازش پاسخ را در سمت کلاینت پیچیده می‌کند.
خروجی سرویس در حالت ورود موفق
خروجی سرویس در حالت ورود موفق


خروجی سرویس در حالت ورود ناموفق
خروجی سرویس در حالت ورود ناموفق


۳.۳ فقدان اسکیمای استاندارد

  • ناهمگونی داده‌ها: فیلدهایی مانند زمان یا قیمت در دوره‌های مختلف، گاه به صورت عددی و گاه به صورت رشته ذخیره می‌شوند (شکل ۵). این ناسازگاری ممکن است ناشی از استفاده از پایگاه داده NoSQL مانند MongoDB باشد، اما برای پلتفرمی با مدل داده‌ای نسبتاً ثابت، انتخاب SQL گزینه بهینه‌تری محسوب می‌شود.
مقدار رشته برای فیلد زمانی
مقدار رشته برای فیلد زمانی
مقدار main_category در حالت موجود
مقدار main_category در حالت موجود
فیلد main_category در حالت null
فیلد main_category در حالت null

۴. جمع‌بندی و توصیه‌های راهبردی

  • بهینه‌سازی SSR/SSG: پیاده‌سازی کامل SSR در Nuxt.js یا مهاجرت به SSG برای صفحات ایستا .
  • بازنگری در طراحی API:استفاده از کدهای وضعیت HTTP متناسب با هر سناریو (مانند ۴۰۱ برای خطای احراز هویت).
  • تعریف اسکیمای واحد برای پاسخ‌های JSON با ابزارهایی مانند Pydantic.
  • یکپارچه‌سازی پایگاه داده: مهاجرت به سیستم‌های SQL مانند PostgreSQL برای تضمین سازگاری داده‌ها.

نتیجه‌گیری

تحلیل معماری مکتب‌خونه نشان می‌دهد که ترکیب فناوری‌های مدرن (مانند Nuxt.js و SOA) بدون توجه دقیق به اصول طراحی، می‌تواند چالش‌های غیرمنتظره‌ای ایجاد کند. با این حال، این چالش‌ها فرصتی برای بهینه‌سازی و الهام‌بخشی به جامعه توسعه‌دهندگان ایرانی است تا با نگاهی انتقادی-سازنده، به استانداردهای جهانی نزدیک‌تر شوند.

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