এই দস্তাবেজটি A/B পার্টিশন সমর্থন করে এমন একটি ডিভাইসে প্রিলোড করা অ্যাপগুলির দ্রুত ইনস্টলেশনের জন্য একটি APK ক্যাশিং সমাধানের নকশা বর্ণনা করে।
OEMগুলি ব্যবহারকারী-মুখী ডেটা স্থানকে প্রভাবিত না করেই নতুন A/B- পার্টিশন করা ডিভাইসগুলিতে বেশিরভাগ খালি B পার্টিশনে সঞ্চিত APK ক্যাশে প্রিলোড এবং জনপ্রিয় অ্যাপগুলি রাখতে পারে। ডিভাইসে একটি APK ক্যাশে উপলব্ধ থাকার মাধ্যমে, নতুন বা সম্প্রতি ফ্যাক্টরি রিসেট ডিভাইসগুলি প্রায় অবিলম্বে ব্যবহারের জন্য প্রস্তুত, Google Play থেকে APK ফাইলগুলি ডাউনলোড করার প্রয়োজন ছাড়াই৷
কেস ব্যবহার করুন
- দ্রুত সেটআপের জন্য বি পার্টিশনে প্রিলোড করা অ্যাপস সংরক্ষণ করুন
- দ্রুত পুনরুদ্ধারের জন্য B পার্টিশনে জনপ্রিয় অ্যাপ সংরক্ষণ করুন
পূর্বশর্ত
এই বৈশিষ্ট্যটি ব্যবহার করতে, ডিভাইসটির প্রয়োজন:
- Android 8.1 (O MR1) রিলিজ ইনস্টল করা হয়েছে
- A/B পার্টিশন বাস্তবায়িত হয়েছে
প্রিলোড করা কন্টেন্ট শুধুমাত্র প্রথম বুট করার সময় কপি করা যাবে। এর কারণ হল A/B সিস্টেম আপডেট সমর্থন করে এমন ডিভাইসগুলিতে, B পার্টিশন আসলে সিস্টেম ইমেজ ফাইল সংরক্ষণ করে না, বরং রিটেল ডেমো রিসোর্স, OAT ফাইল এবং APK ক্যাশে প্রিলোড করা সামগ্রী। সম্পদগুলি /data পার্টিশনে অনুলিপি করার পরে (এটি প্রথম বুটে ঘটে), সিস্টেম ইমেজের আপডেট সংস্করণগুলি ডাউনলোড করার জন্য B পার্টিশনটি ওভার-দ্য-এয়ার (OTA) আপডেট দ্বারা ব্যবহার করা হবে।
অতএব, APK ক্যাশে OTA এর মাধ্যমে আপডেট করা যাবে না; এটি শুধুমাত্র একটি কারখানায় প্রিলোড করা যেতে পারে। ফ্যাক্টরি রিসেট শুধুমাত্র /ডেটা পার্টিশনকে প্রভাবিত করে। OTA ইমেজ ডাউনলোড না হওয়া পর্যন্ত সিস্টেম B পার্টিশনে প্রিলোড করা কন্টেন্ট থাকে। ফ্যাক্টরি রিসেট করার পরে, সিস্টেমটি আবার প্রথম বুটের মধ্য দিয়ে যাবে। এর মানে হল যদি OTA ইমেজ B পার্টিশনে ডাউনলোড করা হয়, এবং তারপর ডিভাইসটি ফ্যাক্টরি রিসেট হয় তাহলে APK ক্যাশিং পাওয়া যায় না।
বাস্তবায়ন
পদ্ধতি 1. সিস্টেম_অন্যান্য পার্টিশনের বিষয়বস্তু
প্রো : ফ্যাক্টরি রিসেট করার পরে প্রিলোড করা সামগ্রী হারিয়ে যায় না - এটি রিবুট করার পরে B পার্টিশন থেকে অনুলিপি করা হবে।
কন : বি পার্টিশনে স্থান প্রয়োজন। ফ্যাক্টরি রিসেটের পর বুট করার জন্য প্রিলোড করা কন্টেন্ট কপি করার জন্য অতিরিক্ত সময় প্রয়োজন।
প্রথম বুট করার সময় প্রিলোড কপি করার জন্য, সিস্টেম /system/bin/preloads_copy.sh
এ একটি স্ক্রিপ্ট কল করে। স্ক্রিপ্টটিকে একটি একক যুক্তি দিয়ে ডাকা হয় ( system_b
পার্টিশনের জন্য শুধুমাত্র পঠনযোগ্য মাউন্ট পয়েন্টের পথ):
এই বৈশিষ্ট্যটি বাস্তবায়ন করতে, এই ডিভাইস-নির্দিষ্ট পরিবর্তনগুলি করুন৷ এখানে মার্লিন থেকে একটি উদাহরণ:
-
device-common.mk
ফাইলে অনুলিপি করা স্ক্রিপ্ট যোগ করুন (এই ক্ষেত্রে,device/google/marlin/device-common.mk
), যেমন: এখানে উদাহরণ স্ক্রিপ্ট উত্স খুঁজুন: device/google/marlin/preloads_copy.sh# Script that copies preloads directory from system_other to data partition PRODUCT_COPY_FILES += \ device/google/marlin/preloads_copy.sh:system/bin/preloads_copy.sh
- প্রয়োজনীয়
/data/preloads
ডিরেক্টরি এবং সাবডিরেক্টরি তৈরি করতেinit.common.rc
ফাইলটি সম্পাদনা করুন: ডিভাইস/google/marlin/init.common.rc- এ উদাহরণmkdir /data/preloads 0775 system system
mkdir /data/preloads/media 0775 system system
mkdir /data/preloads/demo 0775 system system
init
ফাইলের উৎস খুঁজুন -
preloads_copy.te
ফাইলে একটি নতুন SELinux ডোমেন সংজ্ঞায়িত করুন : এখানে SELinux ডোমেন ফাইলের একটি উদাহরণ খুঁজুন: /device/google/marlin/+/main/sepolicy/preloads_copy.tetype preloads_copy, domain, coredomain; type preloads_copy_exec, exec_type, vendor_file_type, file_type; init_daemon_domain(preloads_copy) allow preloads_copy shell_exec:file rx_file_perms; allow preloads_copy toolbox_exec:file rx_file_perms; allow preloads_copy preloads_data_file:dir create_dir_perms; allow preloads_copy preloads_data_file:file create_file_perms; allow preloads_copy preloads_media_file:dir create_dir_perms; allow preloads_copy preloads_media_file:file create_file_perms; # Allow to copy from /postinstall allow preloads_copy system_file:dir r_dir_perms;
- একটি নতুন ডোমেইন নিবন্ধন করুন
/sepolicy/file_contexts
ফাইল: এখানে SELinux প্রসঙ্গ ফাইলের একটি উদাহরণ খুঁজুন: device/google/marlin/sepolicy/preloads_copy.te/system/bin/preloads_copy\.sh u:object_r:preloads_copy_exec:s0
- বিল্ড টাইমে, প্রিলোড করা বিষয়বস্তু সহ ডিরেক্টরি অবশ্যই
system_other
পার্টিশনে কপি করতে হবে: এটি একটি মেকফাইলের পরিবর্তনের একটি উদাহরণ যা বিক্রেতার গিট সংগ্রহস্থল থেকে APK ক্যাশে সংস্থানগুলি অনুলিপি করার অনুমতি দেয় (আমাদের ক্ষেত্রে এটি ছিল vendor/google_devices/marlin/preloads) system_other পার্টিশনের অবস্থানে যা পরে /data/preloads-এ কপি করা হবে যখন ডিভাইস প্রথমবার বুট হয়। সিস্টেম_অন্যান্য ইমেজ প্রস্তুত করতে এই স্ক্রিপ্টটি বিল্ড টাইমে চলে। এটি প্রিলোড করা সামগ্রী বিক্রেতা/google_devices/marlin/preloads-এ উপলব্ধ হবে বলে আশা করে৷ OEM প্রকৃত সংগ্রহস্থলের নাম/পথ বেছে নিতে বিনামূল্যে।# Copy contents of preloads directory to system_other partition PRODUCT_COPY_FILES += \ $(call find-copy-subdir-files,*,vendor/google_devices/marlin/preloads,system_other/preloads)
- APK ক্যাশে
/data/preloads/file_cache
এ অবস্থিত এবং নিম্নলিখিত লেআউট রয়েছে: এটি ডিভাইসের চূড়ান্ত ডিরেক্টরি কাঠামো। যতক্ষণ না চূড়ান্ত ফাইল কাঠামো উপরে বর্ণিত একটি প্রতিলিপি করে ততক্ষণ পর্যন্ত OEMগুলি যে কোনও বাস্তবায়ন পদ্ধতি বেছে নিতে মুক্ত।/data/preloads/file_cache/ app.package.name.1/ file1 fileN app.package.name.N/
পদ্ধতি 2. ব্যবহারকারীর ডেটা ইমেজের বিষয়বস্তু কারখানায় ফ্ল্যাশ করে
এই বিকল্প পদ্ধতিটি অনুমান করে যে প্রিলোড করা বিষয়বস্তু ইতিমধ্যে /data
পার্টিশনের / /data/preloads
ডিরেক্টরিতে অন্তর্ভুক্ত করা হয়েছে।
প্রো : বাক্সের বাইরে কাজ করে - প্রথম বুটে ফাইল কপি করতে ডিভাইস কাস্টমাইজেশন করার দরকার নেই। বিষয়বস্তু ইতিমধ্যেই /data
পার্টিশনে রয়েছে।
কন : ফ্যাক্টরি রিসেট করার পর প্রিলোড করা কন্টেন্ট হারিয়ে যায়। যদিও এটি কারও কারও জন্য গ্রহণযোগ্য হতে পারে, এটি সর্বদা OEM-দের জন্য কাজ নাও করতে পারে যারা গুণমান নিয়ন্ত্রণ পরিদর্শন করার পরে ডিভাইসগুলি ফ্যাক্টরি রিসেট করে।
একটি নতুন @SystemApi পদ্ধতি, getPreloadsFileCache()
, android.content.Context
এ যোগ করা হয়েছে। এটি প্রিলোড করা ক্যাশে একটি অ্যাপ-নির্দিষ্ট ডিরেক্টরিতে একটি পরম পথ ফেরত দেয়।
একটি নতুন পদ্ধতি, IPackageManager.deletePreloadsFileCache
, যোগ করা হয়েছে যা সমস্ত স্থান পুনরুদ্ধার করতে প্রিলোড ডিরেক্টরি মুছে ফেলার অনুমতি দেয়। পদ্ধতিটি শুধুমাত্র SYSTEM_UID সহ অ্যাপ্লিকেশনগুলি দ্বারা কল করা যেতে পারে, যেমন সিস্টেম সার্ভার বা সেটিংস৷
অ্যাপ প্রস্তুতি
শুধুমাত্র বিশেষ সুবিধাপ্রাপ্ত অ্যাপই প্রিলোড ক্যাশে ডিরেক্টরি অ্যাক্সেস করতে পারে। সেই অ্যাক্সেসের জন্য, অ্যাপগুলিকে অবশ্যই /system/priv-app
ডিরেক্টরিতে ইনস্টল করতে হবে।
বৈধতা
- প্রথম বুট করার পরে, ডিভাইসের
/data/preloads/file_cache
ডিরেক্টরিতে বিষয়বস্তু থাকা উচিত। - যদি ডিভাইসের স্টোরেজ কম থাকে তাহলে
file_cache/
ডিরেক্টরির বিষয়বস্তু মুছে ফেলতে হবে।
APK ক্যাশে পরীক্ষা করার জন্য উদাহরণ ApkCacheTest অ্যাপটি ব্যবহার করুন।
- রুট ডিরেক্টরি থেকে এই কমান্ডটি চালিয়ে অ্যাপটি তৈরি করুন:
make ApkCacheTest
- অ্যাপটিকে একটি বিশেষ সুবিধাপ্রাপ্ত অ্যাপ হিসেবে ইনস্টল করুন। (মনে রাখবেন, শুধুমাত্র সুবিধাপ্রাপ্ত অ্যাপই APK ক্যাশে অ্যাক্সেস করতে পারে।) এর জন্য একটি রুটেড ডিভাইস প্রয়োজন:
adb root && adb remount
adb shell mkdir /system/priv-app/ApkCacheTest
adb push $ANDROID_PRODUCT_OUT/data/app/ApkCacheTest/ApkCacheTest.apk /system/priv-app/ApkCacheTest/
adb shell stop && adb shell start
- প্রয়োজনে ফাইল ক্যাশে ডিরেক্টরি এবং এর বিষয়বস্তু অনুকরণ করুন (এছাড়াও রুট সুবিধার প্রয়োজন):
adb shell mkdir -p /data/preloads/file_cache/com.android.apkcachetest
adb shell restorecon -r /data/preloads
adb shell "echo "Test File" > /data/preloads/file_cache/com.android.apkcachetest/test.txt"
- অ্যাপটি পরীক্ষা করুন। অ্যাপটি ইনস্টল করার পরে এবং পরীক্ষা
file_cache
ডিরেক্টরি তৈরি করার পরে, ApkCacheTest অ্যাপটি খুলুন। এটি একটি ফাইলtest.txt
এবং এর বিষয়বস্তু দেখাতে হবে। ইউজার ইন্টারফেসে এই ফলাফলগুলি কীভাবে প্রদর্শিত হয় তা দেখতে এই স্ক্রিনশটটি দেখুন। চিত্র 1. ApkCacheTest ফলাফল।