تقليل حجم OTA

تصف هذه الصفحة التغييرات التي تمت إضافتها إلى AOSP لتقليل تغييرات الملفات غير الضرورية بين الإصدارات. يمكن لمنفذي الأجهزة الذين يحتفظون بأنظمة البناء الخاصة بهم استخدام هذه المعلومات كدليل لتقليل حجم التحديثات عبر الهواء (OTA).

تحتوي تحديثات Android OTA أحيانًا على ملفات تم تغييرها لا تتوافق مع تغييرات الرمز. إنهم في الواقع يقومون ببناء أدوات النظام. يمكن أن يحدث هذا عندما ينتج نفس الكود ، الذي تم إنشاؤه في أوقات مختلفة ، أو من أدلة مختلفة ، أو على أجهزة مختلفة عددًا كبيرًا من الملفات المتغيرة. تزيد هذه الملفات الزائدة من حجم تصحيح OTA وتجعل من الصعب تحديد الرمز الذي تم تغييره.

لجعل محتويات OTA أكثر شفافية ، تتضمن AOSP تغييرات نظام البناء المصممة لتقليل حجم تصحيحات OTA. تم التخلص من تغييرات الملفات غير الضرورية بين الإصدارات ، ويتم تضمين الملفات المتعلقة بالتصحيح فقط في تحديثات OTA. يتضمن AOSP أيضًا أداة فرق البناء ، والتي تقوم بتصفية تغييرات الملفات الشائعة المتعلقة بالبناء لتوفير فرق ملف بناء أنظف ، وأداة تعيين الكتلة ، والتي تساعدك على الحفاظ على تناسق تخصيص الكتلة.

يمكن لنظام الإنشاء إنشاء تصحيحات كبيرة غير ضرورية بعدة طرق. لتخفيف هذا الأمر ، في Android 8.0 والإصدارات الأحدث ، تم تطبيق ميزات جديدة لتقليل حجم التصحيح لكل اختلاف في الملف. تتضمن التحسينات التي قللت من أحجام حزم تحديث OTA ما يلي:

  • استخدام Brotli ، وهو خوارزمية للأغراض العامة والضغط بدون فقد للصور الكاملة في تحديثات الأجهزة غير A / B. يمكن تخصيص Brotli لتحسين الضغط. في التحديثات الكبيرة التي تتكون من كتلتين أو أكثر في نظام الملفات (على سبيل المثال ، system.img ) ، يمكن لمصنعي الأجهزة أو الشركاء إضافة خوارزميات الضغط الخاصة بهم ، ويمكنهم استخدام خوارزميات ضغط مختلفة على كتل مختلفة من نفس التحديث.
  • استخدام إعادة ضغط Puffin ، وهي أداة ترقيع حتمية للتدفقات المنكمشة ، والتي تتعامل مع وظائف الضغط والفرق لتوليد تحديث A / B OTA.
  • تغييرات في استخدام أداة delta-Generation ، مثل كيفية bsdiff مكتبة bsdiff لضغط التصحيحات. في Android 9 والإصدارات الأحدث ، bsdiff أداة bsdiff خوارزمية الضغط التي من شأنها أن تعطي أفضل نتائج ضغط bsdiff .
  • أدت التحسينات التي تم update_engine على update_engine إلى تقليل استهلاك الذاكرة عند تطبيق التصحيحات على تحديثات جهاز A / B.
  • تحسينات لتقسيم ملفات zip الكبيرة لتحديثات OTA القائمة على الكتلة. يقسم وضع في imgdiff ملفات APK كبيرة الحجم ، بناءً على أسماء الإدخال. ينتج عن هذا تصحيح أصغر مقارنة بتقسيم الملفات خطيًا واستخدام أداة bsdiff .

تناقش الأقسام التالية المشكلات المختلفة التي تؤثر على أحجام تحديث OTA وحلولها وأمثلة للتنفيذ في AOSP.

ترتيب الملفات

المشكلة : لا تضمن أنظمة الملفات ترتيب الملفات عند مطالبتك بقائمة من الملفات في دليل ما ، على الرغم من أنها عادةً ما تكون هي نفسها في عملية السحب نفسها. أدوات مثل ls فرز النتائج وفقا لالافتراضي، ولكن وظيفة البدل يستخدمها أوامر مثل find و make لا النوع. قبل استخدام هذه الأدوات ، يجب عليك فرز المخرجات.

الحل: عند استخدام أدوات مثل find و make مع وظيفة البدل، النوع الناتج من هذه الأوامر قبل استخدامها. عند استخدام $(wildcard) أو $(shell find) في ملفات Android.mk ، قم Android.mk أيضًا. تقوم بعض الأدوات ، مثل Java ، بفرز المدخلات ، لذا قبل فرز الملفات ، تحقق من أن الأداة التي تستخدمها لم تقم بذلك بالفعل.

أمثلة: تم إصلاح العديد من الحالات في نظام الإنشاء الأساسي باستخدام all-*-files-under المدمج all-*-files-under الماكرو ، والذي يتضمن all-cpp-files-under (حيث تم نشر العديد من التعريفات في ملفات makefiles أخرى). لمزيد من التفاصيل ، يرجى الرجوع إلى ما يلي:

بناء الدليل

المشكلة: قد يؤدي تغيير الدليل الذي تُبنى فيه الأشياء إلى اختلاف الثنائيات. معظم المسارات في إصدار Android هي مسارات نسبية ، لذا لا __FILE__ في C / C ++ مشكلة. ومع ذلك ، تقوم رموز التصحيح بترميز اسم المسار الكامل افتراضيًا ، ويتم إنشاء .note.gnu.build-id من تجزئة الملف الثنائي الذي تم تجريده مسبقًا ، لذلك سيتغير إذا تغيرت رموز التصحيح.

الحل: تقوم AOSP الآن بجعل مسارات التصحيح نسبية. للحصول على التفاصيل ، راجع CL: https://android.googlesource.com/platform/build/+/6a66a887baadc9eb3d0d60e26f748b8453e27a02 .

الطوابع الزمنية

المشكلة: ينتج عن الطوابع الزمنية في إخراج البناء تغييرات غير ضرورية في الملف. من المحتمل أن يحدث هذا في المواقع التالية:

  • __DATE__/__TIME__/__TIMESTAMP__ في كود C أو C ++.
  • الطوابع الزمنية المضمنة في أرشيفات مضغوطة.

الحلول / الأمثلة: لإزالة الطوابع الزمنية من مخرجات الإصدار ، استخدم الإرشادات الواردة أدناه في __DATE __ / __ TIME __ / __ TIMESTAMP__ في C / C ++. والطوابع الزمنية المضمنة في المحفوظات .

__DATE __ / __ TIME __ / __ TIMESTAMP__ في C / C ++

تنتج وحدات الماكرو هذه دائمًا مخرجات مختلفة لبناءات مختلفة ، لذا لا تستخدمها. فيما يلي بعض الخيارات للتخلص من وحدات الماكرو هذه:

الطوابع الزمنية المضمنة في الأرشيفات (الرمز البريدي ، الجرة)

قام Android 7.0 بإصلاح مشكلة الطوابع الزمنية المضمنة في أرشيفات مضغوطة عن طريق إضافة -X إلى جميع استخدامات الأمر zip . أدى هذا إلى إزالة UID / GID للمنشئ والطابع الزمني الموسع لنظام Unix من ملف zip.

أداة جديدة ، ziptime (موجودة في /platform/build/+/master/tools/ziptime/ ) /platform/build/+/master/tools/ziptime/ تعيين الطوابع الزمنية العادية في رؤوس /platform/build/+/master/tools/ziptime/ المضغوطة. للحصول على تفاصيل ، راجع ملف README .

signapk أداة signapk الطوابع الزمنية لملفات APK التي قد تختلف وفقًا signapk الزمنية للخادم. للحصول على التفاصيل ، راجع CL https://android.googlesource.com/platform/build/+/6c41036bcf35fe39162b50d27533f0f3bfab3028 .

سلاسل الإصدار

المشكلة: تحتوي سلاسل إصدار APK غالبًا على BUILD_NUMBER . حتى إذا لم يتغير شيء آخر في APK ، كنتيجة لذلك ، سيظل ملف APK مختلفًا.

الحل: قم بإزالة رقم الإصدار من سلسلة إصدار APK.

الحل: قم بإزالة رقم الإصدار من سلسلة إصدار APK.

أمثلة:

تفعيل حساب الحقيقة على الجهاز

إذا تم تمكين dm-verity على جهازك ، فستقوم أدوات OTA تلقائيًا باختيار تكوين الحقيقة الخاص بك ، وتمكين حساب الحقيقة على الجهاز. يسمح ذلك بحساب كتل الحقيقة على أجهزة Android ، بدلاً من تخزينها كبايتات أولية في حزمة OTA الخاصة بك. يمكن أن تستخدم كتل Verity حوالي 16 ميجابايت لقسم 2 جيجابايت.

ومع ذلك ، يمكن أن تستغرق صحة الحوسبة على الجهاز وقتًا طويلاً. على وجه التحديد ، يمكن أن يستغرق رمز تصحيح الخطأ الأمامي وقتًا طويلاً. على أجهزة البكسل ، يستغرق الأمر ما يصل إلى 10 دقائق. قد يستغرق الأمر وقتًا أطول على الأجهزة المنخفضة الجودة. إذا كنت ترغب في تعطيل حساب الحقيقة على الجهاز ، ولكن لا تزال تقوم بتمكين dm-verity ، فيمكنك القيام بذلك بتمرير --disable_fec_computation إلى أداة ota_from_target_files عند إنشاء تحديث OTA. تعمل هذه العلامة على تعطيل حساب الحقيقة على الجهاز أثناء تحديثات OTA. يقلل من وقت تثبيت OTA ، لكنه يزيد من حجم حزمة OTA. إذا لم يتم تمكين dm-verity على جهازك ، فلن يكون لتمرير هذه العلامة أي تأثير.

أدوات بناء متسقة

المشكلة: يجب أن تكون الأدوات التي تنشئ ملفات مثبتة متسقة (يجب أن ينتج إدخال معين نفس الإخراج دائمًا).

الحلول / الأمثلة: التغييرات مطلوبة في أدوات البناء التالية:

استخدام أداة فرق البناء

بالنسبة للحالات التي يتعذر فيها استبعاد تغييرات الملفات المتعلقة بالبناء ، فإن AOSP يتضمن أداة فرق البناء ، target_files_diff.py لاستخدامها في مقارنة حزمتي ملفات. تقوم هذه الأداة بإجراء فرق متكرر بين بنائين ، باستثناء تغييرات الملفات الشائعة المتعلقة بالبناء ، مثل

  • التغييرات المتوقعة في مخرجات البناء (على سبيل المثال ، بسبب تغيير رقم الإصدار).
  • التغييرات بسبب المشكلات المعروفة في نظام البناء الحالي.

لاستخدام أداة build diff ، قم بتشغيل الأمر التالي:

target_files_diff.py dir1 dir2

dir1 و dir2 هما dir2 يحتويان على ملفات الهدف المستخرجة لكل بناء.

الحفاظ على اتساق تخصيص الكتلة

بالنسبة لملف معين ، على الرغم من أن محتوياته تظل كما هي بين بنائين ، فقد تكون الكتل الفعلية التي تحتوي على البيانات قد تغيرت. نتيجة لذلك ، يجب أن يقوم المحدث بإجراء إدخال / إخراج غير ضروري لتحريك الكتل لتحديث OTA.

في تحديث Virtual A / B OTA ، يمكن أن تؤدي عمليات الإدخال / الإخراج غير الضرورية إلى زيادة مساحة التخزين المطلوبة بشكل كبير لتخزين لقطة النسخ عند الكتابة. في تحديث OTA غير A / B ، يساهم تحريك الكتل لتحديث OTA في تحديث الوقت نظرًا لوجود المزيد من الإدخال / الإخراج بسبب تحركات الحظر.

لمعالجة هذه المشكلة ، وسعت Google في Android 7.0 أداة make_ext4fs للحفاظ على تناسق تخصيص الكتلة عبر make_ext4fs . و make_ext4fs أداة تقبل اختياري -d base_fs العلم أن محاولات تخصيص الملفات إلى نفس كتل عندما توليد ext4 الصورة. يمكنك استخراج ملفات تعيين الكتل (مثل ملفات خريطة base_fs ) من ملف مضغوط لملفات هدف بناء سابق. لكل قسم ext4 ، يوجد ملف .map في دليل IMAGES (على سبيل المثال ، IMAGES/system.map يتوافق مع قسم system ). يمكن بعد ذلك base_fs ملفات base_fs هذه base_fs عبر PRODUCT_<partition>_BASE_FS_PATH ، كما في هذا المثال:

  PRODUCT_SYSTEM_BASE_FS_PATH := path/to/base_fs_files/base_system.map
  PRODUCT_SYSTEM_EXT_BASE_FS_PATH := path/to/base_fs_files/base_system_ext.map
  PRODUCT_VENDOR_BASE_FS_PATH := path/to/base_fs_files/base_vendor.map
  PRODUCT_PRODUCT_BASE_FS_PATH := path/to/base_fs_files/base_product.map
  PRODUCT_ODM_BASE_FS_PATH := path/to/base_fs_files/base_odm.map

في حين أن هذا لا يساعد في تقليل الحجم الإجمالي لحزمة OTA ، إلا أنه يحسن أداء تحديث OTA عن طريق تقليل كمية الإدخال / الإخراج. بالنسبة لتحديثات A / B الافتراضية ، فإنها تقلل بشكل كبير من مقدار مساحة التخزين اللازمة لتطبيق OTA.

تجنب تحديث التطبيقات

بالإضافة إلى تقليل اختلافات الإنشاء ، يمكنك تقليل أحجام تحديث OTA من خلال استبعاد تحديثات التطبيقات التي تحصل على تحديثات من خلال متاجر التطبيقات. غالبًا ما تشكل حزم APK جزءًا مهمًا من الأقسام المختلفة على الجهاز. قد يكون لتضمين أحدث إصدارات التطبيقات التي يتم تحديثها بواسطة متاجر التطبيقات في تحديث OTA تأثير كبير على حزم OTA ، ولا يوفر فائدة تذكر للمستخدم. بحلول الوقت الذي يتلقى فيه المستخدمون حزمة OTA ، قد يكون لديهم بالفعل التطبيق المحدث ، أو حتى إصدار أحدث ، يتم تلقيه مباشرة من متاجر التطبيقات.