ویرگول
ورودثبت نام
محمد مهدی
محمد مهدی
محمد مهدی
محمد مهدی
خواندن ۲ دقیقه·۷ ساعت پیش

تسلط بر Source Maps و Symbolication: اشکال‌زدایی کد فشرده در محیط تولید

اشکال‌زدایی کد فشرده در محیط تولید: آموزش کامل Source Map و Symbolication

کابوس خطاهای مبهم در تولید

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

TypeError: Cannot read property 'x' of undefined at a.min.js:1:87923

خط شماره ۱، کاراکتر ۸۷۹۲۳ یعنی چه؟ اصلاً کد شما کجاست؟!

این مشکل تمام تیم‌هایی است که کد خود را برای محیط تولید (production) فشرده (minify) و مبهم (obfuscate) می‌کنند. فشرده‌سازی سرعت بارگذاری را بالا می‌برد اما خطاها را غیرقابل خواندن می‌کند.

راه حل چیست؟ Source Map و Symbolication.

Source Map چیست؟

فایل .map یک دیکشنری است که ارتباط بین کد فشرده (همان a.min.js) و کد اصلی شما (مثل index.js) را نگهداری می‌کند.

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

مثال عملی:

- کد اصلی شما: function getUserName(user) { return user.name; }

- بعد از minify: function a(b){return b.name}

- خطا در کد minify: a is not defined

- بعد از اعمال Source Map: خطا در تابع getUserName در خط ۱۲ فایل profile.js

Symbolication چیست؟ (برای اپلیکیشن‌های موبایل)

در اپلیکیشن‌های iOS و اندروید، کرنل سیستم عامل هنگام crash یک آدرس حافظه (مثل 0x1a2b3c4d) برمی‌گرداند. این آدرس برای انسان بی‌معناست.

Symbolication فرآیند تبدیل این آدرس حافظه به نام تابع، نام فایل و شماره خط با استفاده از فایل‌های dSYM (در iOS) یا mapping.txt (در ProGuard اندروید) است.

بدون Symbolication، یک crash report شبیه این است:

0x0000000102a3b4c5

0x0000000102a3b4d0

با Symbolication تبدیل می‌شود به:

applicationDidBecomeActive (AppDelegate.swift:45)

viewDidLoad (HomeViewController.swift:120)

چرا این ابزارها برای هر تیم توسعه‌ای ضروری است؟

۱. صرفه‌جویی در زمان: به جای حدس زدن، دقیقاً محل خطا را می‌بینید.

۲. حذف ردپای کد از سرور عمومی: نیازی نیست فایل‌های .map را روی سرور تولید منتشر کنید. می‌توانید آن‌ها را در ابزارهای داخلی یا سرویس‌های ردیابی خطا نگهداری کنید.

۳. گروه‌بندی هوشمند خطاها: ابزارهای مدرن با استفاده از Source Map خطاهای تکراری را شناسایی و گروه‌بندی می‌کنند.

چالش اصلی: مدیریت نسخه‌ها

اگر Source Map نسخه ۱.۰ را برای خطای نسخه ۱.۱ استفاده کنید، نتیجه اشتباه خواهد بود.

راهکار: همیشه Source Map را همراه با همان build در یک مکان امن (مثل دشبورد ردیابی خطا) آپلود کنید.

یک ابزار پیشنهادی

اگر نمی‌خواهید خودتان زیرساخت مدیریت Source Map را بسازید، سرویس‌هایی مثل Rivium Trace (در آدرس rivium.co) این کار را خودکار کرده‌اند. شما فقط فایل .map را آپلود می‌کنید و بقیه فرآیند symbolication خودکار انجام می‌شود. اما حتی بدون آن هم می‌توانید با ابزارهای خط فرمان مانند source-map در Node.js این کار را انجام دهید.

جمع‌بندی

- همیشه از Source Map در پروژه‌های JavaScript/TypeScript استفاده کنید.

- برای اپلیکیشن‌های موبایل، فایل‌های dSYM یا ProGuard را نگهداری کنید.

- هرگز فایل‌های .map را در پوشه عمومی سرور قرار ندهید.

- فرآیند آپلود نقشه‌ها را در CI/CD خود خودکار کنید.

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

اگر سوالی درباره نحوه تولید Source Map در Webpack، Vite یا Next.js دارید، در کامنت‌ها بپرسید.

کدci cd
۰
۰
محمد مهدی
محمد مهدی
شاید از این پست‌ها خوشتان بیاید