Skip to content

سند ادغام کامل برای به‌روزرسانی تفاضلی برنامه Android (براساس UpgradeLink + DiffUpdater)

I. مفهوم اصلی به‌روزرسانی تفاضلی

به‌روزرسانی تفاضلی (نیز به عنوان به‌روزرسانی افزایشی شناخته می‌شود) راه‌حل کارآمد به‌روزرسانی برنامه است. منطق اصلی آن این است: هنگام به‌روزرسانی برنامه، فقط بخش تفاضلی (که معمولاً "بسته پچ" نامیده می‌شود) بین نسخه فعلی و نسخه هدف را دانلود کنید، نه بسته نصب نسخه کامل هدف (بسته APK).

در مقایسه با به‌روزرسانی کامل سنتی، مزایای اصلی به‌روزرسانی تفاضلی عبارتند از:

  1. کاهش مصرف داده: اندازه بسته پچ تنها 10 تا 30 درصد از APK کامل است (بسته به اختلاف نسخه)، که هزینه داده‌های شبکه را در طول به‌روزرسانی برای کاربران به‌طور قابل‌توجهی کاهش می‌دهد;
  2. بهبود کارایی به‌روزرسانی: بسته‌های پچ کوچکتر سریع‌تر دانلود می‌شوند، به‌ویژه در محیط‌های شبکه ضعیف زمان انتظار به‌روزرسانی را کاهش می‌دهند;
  3. کاهش فشار سرور: سرورها فقط نیاز دارند بسته‌های پچ با اندازه کوچک توزیع کنند، که باعث کاهش استفاده از پهنای باند و مخزن می‌شود.

اصل پایه آن این است که از طریق الگوریتم‌های خاص (مانند BSDiff، HDiffPatch و غیره) داده‌های باینری فایل‌های APK قدیمی و جدید را مقایسه می‌کند، محتویات تفاضلی را استخراج می‌کند تا بسته پچ تولید کند. پس از اینکه کلاینت بسته پچ را دانلود می‌کند، آن را با APK قدیمی محلی ادغام می‌کند تا APK نسخه کامل هدف تولید شود، و در نهایت نصب و به‌روزرسانی را تکمیل می‌کند.

II. معرفی سیستم‌های اصلی

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

####功املیات اصلی:

  1. مدیریت نسخه: از نگهداری اطلاعات نسخه‌های تاریخی و نسخه‌های هدف برنامه پشتیبانی می‌کند، و آدرس‌های ذخیره‌سازی بسته‌های APK و بسته‌های پچ برای هر نسخه را ثبت می‌کند;
  2. پیکربندی قانون به‌روزرسانی: امکان تنظیم قوانین مانند به‌روزرسانی اجباری/اختیاری، به‌روزرسانی خاص کانال، و محدودیت‌های محدوده نسخه را فراهم می‌کند;
  3. تولید و ذخیره بسته پچ: با الگوریتم‌های تفاضلی پیوند برقرار می‌کند تا بسته‌های پچ را براساس APK نسخه‌های قدیمی و جدید به‌طور خودکار تولید و ذخیره کند، و پیوندهای دانلود پایدار ارائه دهد;
  4. تأیید وضعیت به‌روزرسانی: درخواست‌های پرسش نسخه از کلاینت‌ها را دریافت می‌کند و داده‌های اصلی مانند اطلاعات نسخه هدف، آدرس بسته پچ، و قوانین به‌روزرسانی را برمی‌گرداند;
  5. پشتیبانی سازگاری: با دستگاه‌های با نسخه‌های مختلف سیستم Android و معماری‌ها سازگار می‌شود تا'universality فرآیند به‌روزرسانی را تضمین کند.

ارزش اصلی:

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

(II) DiffUpdater: SDK به‌روزرسانی تفاضلی Android

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

####功املیات اصلی:

  1. پردازش بسته پچ: از الگوریتم‌های تفاضلی اصلی (که می‌توانید از طریق پارامتر patchAlgo مشخص کنید) پشتیبانی می‌کند، که امکان ادغام کارآمد APKهای قدیمی محلی با بسته‌های پچ دانلود شده را برای تولید APK نسخه کامل هدف فراهم می‌کند;
  2. مدیریت دانلود: قابلیت دانلود بسته پچ را به‌طور داخلی ارائه می‌دهد، از توقف و ادامه، نظارت بر پیشرفت دانلود، و تلاش مجدد خودکار پس از شکست دانلود پشتیبانی می‌کند;
  3. سازگاری نصب: درخواست مجوز نصب سیستم Android، تأیید فایل APK (MD5/SHA)، نصب بی‌صدا (نیاز به مجوزهای سیستم دارد)، یا راهنمایی نصب دستی را به‌طور خودکار مدیریت می‌کند;
  4. پاسخ‌گویی وضعیت: رویدادهای کلیدی مانند پیشرفت دانلود، وضعیت ادغام، و نتایج نصب را به برنامه برمی‌گرداند، که برای نمایش وضعیت به‌روزرسانی در UI پیش‌طرف سودمند است;
  5. پشتیبانی شخصی‌سازی: از مسیرهای دانلود سفارشی، استایل‌های پاپ‌آپ به‌روزرسانی، منطق مدیریت خطا و غیره پشتیبانی می‌کند تا با نیازهای تعامل برنامه‌های مختلف سازگار شود.

مزایای اصلی:

  • سبک و بدون وابستگی: اندازه SDK کوچک، بدون وابستگی‌های اضافی، جلوگیری از افزایش اندازه بسته برنامه;
  • پایدار و کارآمد: الگوریتم ادغام بهینه‌سازی شده، استفاده کم حافظه، سرعت ادغام بالا، و سازگاری با دستگاه‌های با پیکربندی پایین;
  • ادغام آسان: رابط‌های API مختصر ارائه می‌دهد، که به توسعه‌دهندگان امکان می‌دهد تا به سرعت ادغام کنند بدون توجه به پیاده‌سازی پایه‌ای ادغام تفاضلی.
  1. پیش‌طرف بررسی به‌روزرسانی را راه‌اندازی می‌کند: پس از شروع برنامه یا فعال‌سازی دستی به‌روزرسانی توسط کاربر، UI پیش‌طرف وضعیت پرسش به‌روزرسانی را نمایش می‌دهد. با مشخص کردن پارامتر patchAlgo (انتخاب الگوریتم تفاضلی)، رابط API UpgradeLink را فراخوانی می‌کند و اطلاعاتی مانند شماره نسخه فعلی برنامه و شماره کانال را منتقل می‌کند;
  2. پشتیبان پیکربندی به‌روزرسانی را برمی‌گرداند: UpgradeLink قوانین به‌روزرسانی را بر اساس پارامترهای منتقل شده تأیید می‌کند و نتیجه را برمی‌گرداند (اگر به‌روزرسانی تفاضلی پشتیبانی شود، آدرس بسته پچ، شماره نسخه هدف، اطلاعات تأیید و غیره را برمی‌گرداند؛ اگر پشتیبانی نشود، آدرس APK کامل را برمی‌گرداند و از فرآیند به‌روزرسانی کامل پیروی می‌کند);
  3. کلاینت بسته پچ را پردازش می‌کند: DiffUpdater آدرس بسته پچ بازگشتی توسط UpgradeLink را دریافت می‌کند، دانلود بسته پچ را آغاز می‌کند (با نظارت بر پیشرفت)، و پس از تکمیل دانلود یکپارچگی فایل را تأیید می‌کند;
  4. ادغام تفاضلی برای تولید APK جدید: DiffUpdater الگوریتم تفاضلی مشخص شده را فراخوانی می‌کند تا APK نسخه قدیمی محلی را با بسته پچ دانلود شده ادغام کند، APK نسخه کامل هدف تولید کند، و تأیید MD5 را انجام دهد تا اطمینان حاصل شود که فایل صحیح است;
  5. انعطاف نصب و به‌روزرسانی: DiffUpdater به‌طور خودکار برای مجوزهای نصب درخواست می‌کند، کاربر را راهنمایی می‌کند تا نصب APK نسخه هدف را تکمیل کند، و برنامه به‌طور خودکار نسخه جدید را پس از نصب شروع می‌کند;
  6. مدیریت استثنا: اگر دانلود، ادغام، یا نصب ناموفق باشد، سیستم به‌طور خودکار وضعیت شکست را به‌عقب فراخوانی می‌کند، و کاربران می‌توانند انتخاب کنند عملیات را دوباره تلاش کنند یا به فرآیند به‌روزرسانی کامل سوئیچ کنند.

IV. خلاصه اصلی

  • UpgradeLink مسئول "پشتیبانی پشتیبان" است: قوانین به‌روزرسانی، اطلاعات نسخه، و منابع بسته پچ را ارائه می‌دهد، و مشکلة تصمیم‌گیری "چه چیزی را به‌روزرسانی کنیم و چگونه به‌روزرسانی کنیم" را حل می‌کند;
  • DiffUpdater مسئول "اجرا پیش‌طرف" است: دانلود، ادغام، و نصب بسته پچ را تکمیل می‌کند، و مشکلة اجرا "چگونه پیاده‌سازی به‌روزرسانی کنیم" را حل می‌کند;
  • این دو با هم کار می‌کنند تا راه‌حل کامل به‌روزرسانی تفاضلی "پیکربندی پشتیبان - اجرا پیش‌طرف" را تشکیل دهند، که به توسعه‌دهندگان کمک می‌کند تا با هزینه کم‌ترین،功املیات به‌روزرسانی برنامه کارآمد و صرف‌داده را پیاده‌سازی کنند، و تجربه کاربری و کارایی توسعه را بهبود بخشند.

toolsetlink@163.com