Watchdog استفاده از حافظه فلش را با ردیابی کل مقدار ورودی/خروجی دیسک که توسط همه برنامهها و سرویسها با استفاده از آمار ورودی/خروجی دیسک هر UID که توسط هسته در مکان «/proc/uid_io/stats» در معرض نمایش قرار میگیرد، نظارت میکند. وقتی یک برنامه یا سرویس از آستانه استفاده بیش از حد ورودی/خروجی دیسک فراتر رود، Watchdog اقداماتی را روی برنامه یا سرویس انجام میدهد. آستانه استفاده بیش از حد ورودی/خروجی دیسک و اقدامی که برای استفاده بیش از حد انجام می شود در پیکربندی استفاده بیش از حد از ورودی/خروجی دیسک از پیش تعریف شده است.
آستانه استفاده بیش از حد
- آستانه استفاده بیش از حد ورودی/خروجی دیسک به صورت روزانه اعمال میشود، یعنی همه نوشتههای ایجاد شده توسط یک برنامه/سرویس از ابتدای روز تقویم فعلی UTC جمعآوری میشوند و در برابر آستانههای تعریفشده در تنظیمات استفاده بیش از حد بررسی میشوند.
- هنگامی که یک وسیله نقلیه چندین بار در یک روز مشخص راه اندازی می شود، ماژول Watchdog آمار استفاده از ورودی/خروجی دیسک را در حافظه فلش ذخیره می کند و آنها را از ابتدای روز تقویم فعلی UTC جمع می کند.
اقدامات استفاده بیش از حد
هنگامی که یک برنامه به طور مکرر از آستانه استفاده بیش از حد ورودی/خروجی دیسک تعریف شده فراتر رود، Watchdog اقداماتی را انجام می دهد که در پیکربندی استفاده بیش از حد تعریف شده است.
- همه برنامهها و سرویسهای فروشنده برای ثبات کلی سیستم حیاتی در نظر گرفته میشوند، بنابراین در استفاده بیش از حد از ورودی/خروجی دیسک پایان نمییابند. با این حال، پیکربندی استفاده بیش از حد میتواند فهرستی از برنامهها و سرویسهای فروشنده را مشخص کند.
- تمام برنامه های شخص ثالث قابل پایان شدن هستند.
هنگامی که یک برنامه یا سرویس ایمن برای پایان یافتن است، Watchdog برنامه یا سرویس را با وضعیت مؤلفه برنامه PackageManager.COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED
غیرفعال می کند.
پیکربندی استفاده بیش از حد
پیکربندی استفاده بیش از حد شامل آستانه ها و اقدامات استفاده بیش از حد ورودی/خروجی دیسک است. تنظیمات پیشفرض استفاده بیش از حد در تصاویر سیستم و فروشنده تعریف شده و همراه با ساخت ارسال میشوند. فروشندگان می توانند به صورت اختیاری پیکربندی فروشنده را در تصویر فروشنده قرار دهند. هنگامی که پیکربندی فروشنده ارائه نمی شود، پیکربندی سیستم برای برنامه ها و سرویس های فروشنده نیز استفاده می شود.
Watchdog APIهای سیستم را از طریق CarWatchdogManager
افشا میکند، که به برنامهها یا سرویسهای فروشندگان اجازه میدهد پیکربندی فروشنده را در هر زمان بهروزرسانی کنند.
تعریف پیکربندی استفاده بیش از حد
پیکربندی استفاده بیش از حد بر اساس نوع مؤلفه تقسیم می شود، به عنوان مثال، سیستم، فروشنده، و شخص ثالث. OEM ها باید فقط پیکربندی مؤلفه فروشنده را به روز کنند.
پیکربندی فروشنده
پیکربندی فروشنده آستانهها و اقدامات استفاده بیش از حد ورودی/خروجی دیسک را برای همه برنامهها و سرویسهای فروشنده و همه نقشهها و برنامههای رسانه تعریف میکند. پیکربندی شامل فیلدهای پیکربندی زیر است.
- پیشوندهای بسته فروشنده تمام بسته های نصب شده در پارتیشن فروشنده به عنوان بسته های فروشنده در نظر گرفته می شوند. علاوه بر این بسته ها، فروشندگان می توانند بسته های از پیش نصب شده را به عنوان بسته های فروشنده با افزودن پیشوندهای بسته به پیکربندی پیشوندهای بسته فروشنده طبقه بندی کنند. این پیکربندی عبارات منظم را نمی پذیرد.
- بسته های ایمن تا پایان . فروشندگان می توانند با افزودن نام بسته های کامل به پیکربندی بسته های امن برای پایان، مشخص کنند که کدام بسته های فروشنده ایمن برای پایان دادن هستند.
- نگاشت دسته بندی برنامه ها فروشندگان می توانند هر بسته (از جمله بسته های شخص ثالث) را به یکی از دو دسته برنامه پشتیبانی شده - نقشه و برنامه های رسانه نگاشت کنند. این نگاشت برای ارائه نقشهها و برنامههای رسانهای انجام میشود که آستانه استفاده بیش از حد از دیسک ورودی/خروجی بالاتری دارند، زیرا این برنامهها تمایل به دانلود و نوشتن دادههای بیشتری روی دیسک نسبت به انواع دیگر برنامهها دارند.
- آستانه های سطح مؤلفه . آستانههای عمومی را برای همه بستههای فروشنده تعریف میکند (یعنی بستههایی که تحت پوشش آستانههای خاص بسته یا آستانههای خاص دستهبندی برنامه نیستند، این آستانهها را دریافت میکنند). هنگام تعریف پیکربندی استفاده بیش از حد از ورودی/خروجی دیسک، فروشنده ها باید آستانه های غیرصفری در سطح مؤلفه را تعریف کنند.
- آستانه های خاص بسته فروشندگان می توانند آستانه های خاصی را برای بسته های فروشنده خاص تعریف کنند. نگاشتها باید شامل نام کامل بسته باشد. آستانه های تعریف شده در این پیکربندی بر آستانه های تعریف شده در تنظیمات دیگر برای یک بسته معین اولویت دارند.
- آستانه های خاص دسته برنامه . فروشندگان می توانند آستانه های ویژه ای را برای دسته بندی برنامه های خاص مشخص کنند. دستههای برنامه باید یکی از دستههای پشتیبانیشده باشد - برنامههای Maps و Media. آستانه های تعریف شده در این پیکربندی با استفاده از نگاشت های دسته برنامه به بسته های خاصی نگاشت می شوند.
- آستانه های گسترده سیستم فروشندگان نباید این پیکربندی را مشخص کنند.
پیشوندهای بسته فروشنده ، بستههای ایمن تا پایان ، آستانههای سطح مؤلفه ، و پیکربندیهای آستانه خاص بسته فقط توسط پیکربندی فروشنده برای برنامهها و سرویسهای فروشنده قابل بهروزرسانی هستند. پیکربندی آستانه های خاص دسته برنامه را می توان فقط توسط پیکربندی فروشنده برای همه نقشه ها و برنامه های رسانه به روز کرد.
آستانه های استفاده بیش از حد حاوی مقدار بایت هایی هستند که اجازه نوشتن در طول:
- حالت پیشزمینه برنامه یا سرویس در مقابل حالت پسزمینه
- حالت گاراژ سیستم
این طبقهبندی به کاربر اجازه میدهد تا برنامهها و سرویسهای پیشزمینه اطلاعات بیشتری را نسبت به برنامهها و سرویسهای پسزمینه بنویسد. در حالت Garage، برنامهها و سرویسها تمایل دارند بهروزرسانیها را دانلود کنند، بنابراین هر کدام به آستانه بالاتری نسبت به برنامهها و سرویسهایی که در حالتهای دیگر اجرا میشوند نیاز دارند.
تنظیمات سیستم و شخص ثالث
OEM ها نباید سیستم و پیکربندی های شخص ثالث را به روز کنند.
- پیکربندی سیستم آستانهها و اقدامات استفاده بیش از حد ورودی/خروجی را برای برنامهها و سرویسهای سیستم تعریف میکند.
- این پیکربندی همچنین میتواند نگاشتهای دسته برنامه را بهروزرسانی کند. بنابراین، این فیلد پیکربندی بین پیکربندی های سیستم و فروشنده به اشتراک گذاشته می شود.
- پیکربندی شخص ثالث آستانه هایی را برای همه برنامه های شخص ثالث تعریف می کند. همه برنامه هایی که از قبل در سیستم نصب نشده اند، برنامه های شخص ثالث هستند.
- همه برنامههای شخص ثالث آستانههای یکسانی را دریافت میکنند (به عنوان مثال، هیچ برنامه شخص ثالث آستانههای خاصی را دریافت نمیکند) به جز نقشهها و برنامههای رسانهای که آستانههای آنها توسط پیکربندی فروشنده تعریف میشوند.
- آستانههای استفاده بیش از حد ورودی/خروجی دیسک زیر آستانههای پیشفرض برای برنامههای شخص ثالث هستند. این آستانه ها همراه با تصویر سیستم ارسال می شوند.
- 3 گیگابایت در حالت پیش زمینه برنامه بنویسید.
- 2 گیگابایت در حالت پسزمینه برنامه بنویسید.
- 4 گیگابایت در حالت گاراژ سیستم بنویسید.
- اینها آستانه های پایه هستند. این آستانه ها با یادگیری بیشتر در مورد استفاده از ورودی/خروجی دیسک به روز می شوند.
استفاده بیش از حد از پیکربندی قالب XML
پیکربندی پیش فرض فروشنده را می توان (این اختیاری است) در مکان /vendor/etc/automotive/watchdog/resource_overuse_configuration.xml
در تصویر ساخت قرار داد. وقتی این پیکربندی مشخص نشده باشد، پیکربندی تعریف شده توسط سیستم برای برنامهها و سرویسهای فروشنده نیز اعمال میشود.
فایل XML باید فقط یک تگ برای هر فیلد پیکربندی داشته باشد. پیکربندی استفاده بیش از حد I/O باید در فایل XML تعریف شود. تمام مقادیر آستانه باید در واحد MiB مشخص شود.
نمونه پیکربندی XML در زیر ارائه شده است:
<resourceOveruseConfiguration version="1.0"> <componentType> VENDOR </componentType> <!-- List of safe to kill vendor packages. --> <safeToKillPackages> <package> com.vendor.package.A </package> <package> com.vendor.package.B </package> </safeToKillPackages> <!-- List of vendor package prefixes. --> <vendorPackagePrefixes> <packagePrefix> com.vendor.package </packagePrefix> </vendorPackagePrefixes> <!-- List of unique package names to app category mappings. --> <packagesToAppCategoryTypes> <packageAppCategory type="MEDIA"> com.vendor.package.A </packageAppCategory> <packageAppCategory type="MAPS"> com.google.package.B </packageAppCategory> <packageAppCategory type="MEDIA"> com.third.party.package.C </packageAppCategory> </packagesToAppCategoryTypes> <ioOveruseConfiguration> <!-- Thresholds in MiB for all vendor packages that don't have package specific thresholds. --> <componentLevelThresholds> <state id="foreground_mode"> 1024 </state> <state id="background_mode"> 512 </state> <state id="garage_mode"> 3072 </state> </componentLevelThresholds> <packageSpecificThresholds> <!-- IDs must be unique --> <perStateThreshold id="com.vendor.package.C"> <state id="foreground_mode"> 400 </state> <state id="background_mode"> 100 </state> <state id="garage_mode"> 200 </state> </perStateThreshold> <perStateThreshold id="com.vendor.package.D"> <state id="foreground_mode"> 1024 </state> <state id="background_mode"> 500 </state> <state id="garage_mode"> 2048 </state> </perStateThreshold> </packageSpecificThresholds> <!-- Application category specific thresholds. --> <appCategorySpecificThresholds> <!-- One entry per supported application category --> <perStateThreshold id="MEDIA"> <state id="foreground_mode"> 600 </state> <state id="background_mode"> 700 </state> <state id="garage_mode"> 1024 </state> </perStateThreshold> <perStateThreshold id="MAPS"> <state id="foreground_mode"> 800 </state> <state id="background_mode"> 900 </state> <state id="garage_mode"> 2048 </state> </perStateThreshold> </appCategorySpecificThresholds> </ioOveruseConfiguration> </resourceOveruseConfiguration>
پیکربندی استفاده بیش از حد را از طریق APIهای سیستم CarWatchdogManager به روز کنید
پیکربندی XML فوق فقط در تصویر ساخت قابل ارائه است. اگر یک OEM تصمیم بگیرد که پیکربندی روی دستگاه را پس از انتشار یک بیلد به روز کند، میتواند از APIهای زیر برای ایجاد تغییرات در پیکربندی روی دستگاه استفاده کند.
- مجوز
Car.PERMISSION_CONTROL_CAR_WATCHDOG_CONFIG
را به تماسگیرنده اعطا کنید. - برای به روز رسانی و تنظیم تنظیمات جدید باید از تنظیمات موجود استفاده کنید. از API
CarWatchdogManager.getResourceOveruseConfigurations
برای دریافت تنظیمات موجود استفاده کنید. اگر از پیکربندیهای موجود استفاده نمیشود، همه پیکربندیها (از جمله پیکربندیهای سیستم و شخص ثالث) رونویسی میشوند، که توصیه نمیشود. - پیکربندی های موجود را با تغییرات دلتا به روز کنید و پیکربندی های جدید را تنظیم کنید. پیکربندی سیستم و اجزای شخص ثالث را به روز نکنید .
- از API
CarWatchdogManager.setResourceOveruseConfigurations
برای تنظیم تنظیمات جدید استفاده کنید. - برای دریافت و تنظیم تنظیمات استفاده بیش از حد ورودی/خروجی دیسک، از پرچم
CarWatchdogManager.FLAG_RESOURCE_OVERUSE_IO
استفاده کنید.
در اینجا یک نمونه پیاده سازی است که پیکربندی های استفاده بیش از حد از منابع را به روز می کند:
void updateResourceOveruseConfigurations() { CarWatchdogManager manager = (CarWatchdogManager) car.getCarManager(Car.CAR_WATCHDOG_SERVICE); List<ResourceOveruseConfiguration> resourceOveruseConfigurations = manager.getResourceOveruseConfigurations( CarWatchdogManager.FLAG_RESOURCE_OVERUSE_IO); List<ResourceOveruseConfiguration> newResourceOveruseConfigurations = new List<>(); ResourceOveruseConfiguration vendorConfiguration; for(ResourceOveruseConfiguration config : resourceOveruseConfigurations) { // Do not update the configurations of the system and third-party component types. if (config.getComponentType() != ResourceOveruseConfiguration.COMPONENT_TYPE_VENDOR) { newResourceOveruseConfigurations.add(config); continue; } vendorConfiguration = config; } if (vendorConfiguration == null) { ResourceOveruseConfiguration.Builder vendorConfigBuilder = new ResourceOveruseConfiguration.Builder(); initializeConfig(vendorConfigBuilder); newResourceOveruseConfigurations.add(vendorConfigBuilder.build()); } else { ResourceOveruseConfiguration newVendorConfig = updateConfig(vendorConfiguration); newResourceOveruseConfigurations.add(newVendorConfig); } int result = manager.setResourceOveruseConfigurations( newResourceOveruseConfigurations, if (result != CarWatchdogManager.RETURN_CODE_SUCCESS) { // Failed to set the resource overuse configurations. } } /** Sets the delta between the old configuration and the new configuration. */ ResourceOveruseConfiguration updateConfig( ResourceOveruseConfiguration oldConfiguration) { // Replace com.vendor.package.A with com.vendor.package.B in the safe-to-kill list. List<String> safeToKillPackages = oldConfiguration.getSafeToKillPackages(); safeToKillPackages.remove("com.vendor.package.A"); safeToKillPackages.add("com.vendor.package.B"); ResourceOveruseConfiguration.Builder configBuilder = new ResourceOveruseConfiguration.Builder( oldConfiguration.getComponentType(), safeToKillPackages, oldConfiguration.getVendorPackagePrefixes(), oldConfiguration.getPackagesToAppCategoryTypes()); configBuilder.addVendorPackagePrefixes("com.vendor."); configBuilder.addPackagesToAppCategoryTypes("com.vendor.package.B", ResourceOveruseConfiguration.APPLICATION_CATEGORY_TYPE_MAPS); IoOveruseConfiguration oldIoConfiguration = oldConfiguration.getIoOveruseConfiguration(); IoOveruseConfiguration.Builder ioConfigBuilder = new IoOveruseConfiguration.Builder( oldIoConfiguration.getComponentLevelThresholds(), oldIoConfiguration.getPackageSpecificThresholds(), oldIoConfiguration.getAppCategorySpecificThresholds(), oldIoConfiguration.getSystemWideThresholds()); // Define the amount of bytes based on the flash memory specification, expected lifetime, // and estimated average amount of bytes written by a package during different modes. ioConfigBuilder.addPackageSpecificThresholds("com.vendor.package.B", new PerStateBytes(/* foregroundModeBytes= */ 2 * 1024 * 1024 * 1024, /* backgroundModeBytes= */ 500 * 1024 * 1024, /* garageModeBytes= */ 3 * 1024 * 1024 * 1024)); return configBuilder.setIoOveruseConfiguration(ioConfigBuilder.build()).build(); }
برنامه هایی که بر استفاده بیش از حد از منابع خود نظارت می کنند
برنامههای فروشنده و شخص ثالث میتوانند اعلانهای استفاده بیش از حد از منابع خاص برنامه را از Watchdog یا نظرسنجی CarWatchdogManager
برای آمار استفاده بیش از حد از منابع خاص برنامه تا 30 روز گذشته گوش دهند.
به اعلانهای استفاده بیش از حد از منابع گوش دهید
برنامهها میتوانند شنونده استفاده بیش از حد از منابع را پیادهسازی کنند و شنونده را در CarWatchdogManager
ثبت کنند تا زمانی که از 80 درصد یا 100 درصد آستانه استفاده بیش از حد دیسک ورودی/خروجی خود فراتر میروند، اعلانهای خاص برنامه را دریافت کنند. برنامهها میتوانند از این اعلانها برای موارد زیر استفاده کنند:
- آمار استفاده بیش از حد ورودی/خروجی دیسک را برای تجزیه و تحلیل آفلاین ثبت کنید. توسعه دهندگان برنامه می توانند از این گزارش برای رفع اشکال مشکل استفاده بیش از حد ورودی/خروجی دیسک استفاده کنند.
- نوشتن ورودی/خروجی دیسک را تا زمانی که شمارنده های استفاده بیش از حد بازنشانی شوند، کاهش دهید.
کلاینت جاوا
- با به ارث بردن
CarWatchdogManager.ResourceOveruseListener
شنونده را پیاده سازی کنید:class ResourceOveruseListenerImpl implements CarWatchdogManager.ResourceOveruseListener { @Override public void onOveruse( @NonNull ResourceOveruseStats resourceOveruseStats) { // 1. Log/Upload resource overuse metrics. // 2. Reduce writes until the counters reset. IoOveruseStats ioOveruseStats = resourceOveruseStats.getIoOveruseStats(); // Stats period - [ioOveruseStats.getStartTime(), ioOveruseStats.getStartTime() // + ioOveruseStats.getDurationInSeconds()] // Total I/O overuses - ioOveruseStats.getTotalOveruses() // Total bytes written - ioOveruseStats.getTotalBytesWritten() // Remaining write bytes for the current UTC calendar day - // ioOveruseStats.getRemainingWriteBytes() } } }
- با تماس با
CarWatchdogManager.addResourceOveruseListener
، نمونه شنونده را ثبت کنیدprivate void addResourceOveruseListener() { CarWatchdogManager manager = (CarWatchdogManager) car.getCarManager(Car.CAR_WATCHDOG_SERVICE); // Choose a proper executor to handle resource overuse notifications. Executor executor = mContext.getMainExecutor(); manager.addResourceOveruseListener( executor, CarWatchdogManager.FLAG_RESOURCE_OVERUSE_IO, mListenerImpl); }
- هنگامی که برنامه گوش دادن را به پایان رساند، نمونه شنونده را لغو ثبت کنید:
private void removeResourceOveruseListener() { CarWatchdogManager manager = (CarWatchdogManager) car.getCarManager(Car.CAR_WATCHDOG_SERVICE); mCarWatchdogManager.removeResourceOveruseListener( mListenerImpl); }
مشتری بومی
-
carwatchdog_aidl_interface-ndk_platform
را در وابستگیshared_libs
قانون ساخت قرار دهید.Android.bp
cc_binary { name: "sample_native_client", srcs: [ "src/*.cpp" ], shared_libs: [ "carwatchdog_aidl_interface-ndk_platform", "libbinder_ndk", ], vendor: true, }
- خط مشی SELinux را اضافه کنید تا به دامنه سرویس فروشنده اجازه استفاده از binder (ماکرو
binder_user
) را بدهد و دامنه سرویس فروشنده را به دامنه مشتریcarwatchdog
(carwatchdog_client_domain macro)
اضافه کنید. کد زیر را برایsample_client.te
وfile_contexts
ببینید.sample_client.te
type sample_client, domain; type sample_client_exec, exec_type, file_type, vendor_file_type; carwatchdog_client_domain(sample_client) init_daemon_domain(sample_client) binder_use(sample_client)
file_contexts
/vendor/bin/sample_native_client u:object_r:sample_client_exec:s0
- با به ارث بردن
BnResourceOveruseListener
شنونده استفاده بیش از حد از منابع را پیاده سازی کنید. برای رسیدگی به اعلانهای استفاده بیش از حد از منابعBnResourceOveruseListener::onOveruse
لغو کنید.ResourceOveruseListenerImpl.h
class ResourceOveruseListenerImpl : public BnResourceOveruseListener { public: ndk::ScopedAStatus onOveruse( ResourceOveruseStats resourceOveruseStats) override; private: void initialize(); void terminate(); std::shared_ptr<ICarWatchdog> mWatchdogServer; std::shared_ptr<IResourceOveruseListener> mListener; }
ResourceOveruseListenerImpl.cpp
ndk::ScopedAStatus ResourceOveruseListenerImpl::onOveruse( ResourceOveruseStats resourceOveruseStats) { // 1. Log/Upload resource overuse metrics. // 2. Reduce writes until the counters reset. if (stats.getTag() != ResourceOveruseStats::ioOveruseStats) { // Received resourceOveruseStats doesn't contain I/O overuse stats. } const IoOveruseStats& ioOveruseStats = stats.get(); // Stats period - [ioOveruseStats.startTime, // ioOveruseStats.startTime + ioOveruseStats.durationInSeconds] // Total I/O overuses - ioOveruseStats.totalOveruses // Total bytes written - ioOveruseStats.writtenBytes // Remaining write bytes for the current UTC calendar day - // ioOveruseStats.remainingWriteBytes return ndk::ScopedAStatus::ok(); }
- یک مخزن رشته بایندر راهاندازی کنید و شنونده استفاده بیش از حد از منابع را با سرور Watchdog ثبت کنید. سرور Watchdog تحت نام سرویس
android.automotive.watchdog.ICarWatchdog/default
ثبت شده است.main.cpp
int main(int argc, char** argv) { ABinderProcess_setThreadPoolMaxThreadCount(1); ABinderProcess_startThreadPool(); std::shared_ptr<ResourceOveruseListenerImpl> listener = ndk::SharedRefBase::make<ResourceOveruseListenerImpl>(); // The listener is added in initialize(). listener->initialize(); ... Run service ... // The listener is removed in terminate(). listener->terminate(); }
ResourceOveruseListenerImpl.cpp
void ResourceOveruseListener::initialize() { ndk::SpAIBinder binder(AServiceManager_getService( "android.automotive.watchdog.ICarWatchdog/default")); std::shared_ptr<ICarWatchdog> server = ICarWatchdog::fromBinder(binder); mWatchdogServer = server; std::shared_ptr<IResourceOveruseListener> listener = IResourceOveruseListener::fromBinder(this->asBinder()); mWatchdogServer->addResourceOveruseListener( std::vector<int>{ResourceType.IO}, listener); mListener = listener; } void ResourceOveruseListener::terminate() { mWatchdogServer->removeResourceOveruseListener(mListener); }
آمار استفاده بیش از حد از منابع نظرسنجی
برنامهها میتوانند از CarWatchdogManager برای آمار استفاده بیش از حد از ورودی/خروجی برنامه ATS در 30 روز اخیر نظرسنجی کنند.
کلاینت جاوا
برای دریافت آمار استفاده بیش از حد از منابع، از CarWatchdogManager.getResourceOveruseStats
استفاده کنید. پرچم CarWatchdogManager.FLAG_RESOURCE_OVERUSE_IO
را پاس کنید تا آمار استفاده بیش از حد دیسک ورودی/خروجی را دریافت کنید.
private void getResourceOveruseStats() { CarWatchdogManager manager = (CarWatchdogManager) car.getCarManager(Car.CAR_WATCHDOG_SERVICE); // Returns resource overuse stats with I/O overuse stats for the past // 7 days. Stats are available for up to the past 30 days. ResourceOveruseStats resourceOveruseStats = mCarWatchdogManager.getResourceOveruseStats( CarWatchdogManager.FLAG_RESOURCE_OVERUSE_IO, CarWatchdogManager.STATS_PERIOD_PAST_7_DAYS); IoOveruseStats ioOveruseStats = resourceOveruseStats.getIoOveruseStats(); // Stats period - [ioOveruseStats.getStartTime(), ioOveruseStats.getStartTime() // + ioOveruseStats.getDurationInSeconds()] // Total I/O overuses - ioOveruseStats.getTotalOveruses() // Total bytes written - ioOveruseStats.getTotalBytesWritten() // Remaining write bytes for the UTC calendar day - // ioOveruseStats.getRemainingWriteBytes() }
مشتری بومی
برای دریافت آمار استفاده بیش از حد از منابع، از CarWatchdogServer.getResourceOveruseStats
استفاده کنید. برای واکشی آمار استفاده بیش از حد دیسک ورودی/خروجی، فهرست ResourceType.IO
را ارسال کنید.
void getResourceOveruseStats() { ndk::SpAIBinder binder(AServiceManager_getService( "android.automotive.watchdog.ICarWatchdog/default")); std::shared_ptr<ICarWatchdog> server = ICarWatchdog::fromBinder(binder); // Returns the stats only for the current UTC calendar day. const std::vector<ResourceOveruseStats> resourceOveruseStats; ndk::ScopedAStatus status = server.getResourceOveruseStats( std::vector<int>{ResourceType.IO}, &resourceOveruseStats); if (!status.isOk()) { // Failed to get the resource overuse stats. return; } for (const auto& stats : resourceOveruseStats) { if (stats.getTag() != ResourceOveruseStats::ioOveruseStats) { continue; } const IoOveruseStats& ioOveruseStats = stats.get(); // Stats period - [ioOveruseStats.startTime, // ioOveruseStats.startTime + ioOveruseStats.durationInSeconds] // Total I/O overuses - ioOveruseStats.totalOveruses // Total bytes written - ioOveruseStats.writtenBytes // Remaining write bytes for the current UTC calendar day - // ioOveruseStats.remainingWriteBytes } }
استفاده بیش از حد از منابع تجربه کاربری
بخشهای زیر تجربه کاربر در هنگام استفاده بیش از حد از منابع را شرح میدهند.
تنظیمات عملکرد برنامه را اولویت بندی کنید
صفحه تنظیمات برنامه حاوی تنظیماتی برای Prioritize app performance
است (تصویر زیر را ببینید)، که به کاربران اجازه میدهد عملکرد برنامه را نسبت به سیستم و عملکرد سختافزار بلندمدت اولویتبندی کنند. این تنظیم فقط برای برنامههایی در دسترس است که در صورت استفاده بیش از حد از منابع قابل پایان هستند. در غیر این صورت، این تنظیم غیرفعال است. هنگامی که این تنظیم برای یک برنامه غیرفعال می شود (تنظیم پیش فرض)، برنامه می تواند در صورت استفاده بیش از حد از منابع خاتمه یابد. در غیر این صورت، برنامه با استفاده بیش از حد از منابع خاتمه نمی یابد.
هنگامی که کاربر این تنظیم را تغییر می دهد، گفتگوی تأیید زیر پیامدهای تغییر روی تنظیمات را توضیح می دهد:
پس از 90 روز، این تنظیم به طور خودکار به حالت پیش فرض بازنشانی می شود. محدودیت روز را می توان با یک برنامه روکش RRO با استفاده از watchdogUserPackageSettingsResetDays
، حداکثر تا 180 روز تغییر داد. برای کسب اطلاعات بیشتر، به تغییر مقدار منابع برنامه در زمان اجرا مراجعه کنید. تگ همپوشانی مثال زیر را می توان در AndroidManifest.xml
گنجاند:
<overlay android:priority="<insert-value>" android:targetPackage="com.android.car.updatable" android:targetName="CarServiceCustomization" android:resourcesMap="@xml/overlays" />
در res/values/config.xml
:
<resources> <integer name="watchdogUserPackageSettingsResetDays">value</integer> </resources>
در res/xml/overlays.xml
:
<overlay> <item target="integer/watchdogUserPackageSettingsResetDays" value="@integer/watchdogUserPackageSettingsResetDays" /> </overlay>
تنظیمات برنامه های تاثیرگذار بر عملکرد
برنامه تنظیمات شامل بخش برنامههای تأثیرگذار بر عملکرد است (شکل 1 را ببینید). با ضربه زدن، لیستی از برنامه هایی که به دلیل استفاده بیش از حد از حافظه فلش محدود شده اند و بر عملکرد سیستم تأثیر منفی می گذارد، نمایش داده می شود. این از الزام CDD 3.5.1 پیروی می کند [C-1-1] .
شکل 1. برنامه های تاثیرگذار بر عملکرد.
برنامه هایی که به دلیل استفاده بیش از حد از منابع خاتمه یافته اند در اینجا فهرست شده اند (شکل 2 را ببینید). برنامه های لیست شده را می توان اولویت بندی کرد. برای کسب اطلاعات بیشتر، اولویت بندی تنظیمات عملکرد برنامه را ببینید.
شکل 2. لیست برنامه هایی که به دلیل استفاده بیش از حد از منابع خاتمه یافته اند.
اطلاع رسانی کاربر
هنگامی که یک برنامه یا سرویس به طور مکرر از ورودی/خروجی دیسک بیش از حد استفاده می کند (به عنوان مثال، داده ها را فراتر از آستانه های تعریف شده روی دیسک می نویسد) و در صورت استفاده بیش از حد از منابع، امکان خاتمه آن ایمن است، پس از ورود وسیله نقلیه به مجوز راننده، به کاربر اطلاع داده می شود. - حالت حواس پرتی
اولین اعلان کاربر (در حین درایو) به عنوان اعلان سرآغاز و سایر اعلان ها در مرکز اطلاع رسانی ارسال می شود.
به عنوان مثال، هنگامی که یک برنامه به طور مکرر از ورودی/خروجی دیسک بیش از حد استفاده می کند، کاربر اعلان زیر را دریافت می کند:
- هنگامی که کاربر روی دکمه اولویت برنامه کلیک می کند، صفحه تنظیمات برنامه راه اندازی می شود، جایی که کاربر می تواند تنظیمات عملکرد برنامه اولویت بندی را روشن یا خاموش کند.
- هنگامی که کاربر روی دکمه غیرفعال کردن برنامه کلیک می کند، برنامه غیرفعال می شود تا زمانی که کاربر برنامه را راه اندازی کند یا آن را در صفحه تنظیمات برنامه فعال کند.
- برای برنامه های غیر قابل نصب، دکمه Disable app با دکمه Uninstall app جایگزین می شود. هنگامی که کاربر روی دکمه Uninstall app کلیک می کند، صفحه تنظیمات برنامه باز می شود که کاربر می تواند برنامه را حذف نصب کند.
توصیه برای پیاده سازی لانچر
وقتی برنامهها به دلیل استفاده بیش از حد از منابع غیرفعال میشوند، برنامهها از برنامه راهانداز پیشفرض ناپدید میشوند زیرا CarService وضعیت فعال برنامهها را بهعنوان PackageManager.COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED
بهروزرسانی میکند.COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED. OEM ها باید اجرای لانچر داخلی را به روز کنند تا این برنامه ها را غیرعادی نشان دهند تا در صورت نیاز کاربران بتوانند از آنها استفاده کنند. توصیههای زیر را بر اساس نسخهی ساخت مشاهده کنید.
انتشار اندروید SC V2
- پیادهسازی راهانداز باید از پرچم
MATCH_DISABLED_UNTIL_USED_COMPONENTS
هنگام بازیابی لیست بستهها برای نمایش در راهانداز استفاده کند. - وقتی کاربر روی برنامهای کلیک میکند که در وضعیت
PackageManager.COMPONENT_ENABLED_STATE_DISABLED_UNTIL_USED
است، برنامه راهانداز باید برنامه را با تنظیم وضعیت فعال بهعنوان فعال کند: