অ্যান্ড্রয়েড লো মেমরি কিলার ডেমন ( lmkd
) প্রক্রিয়া চলমান অ্যান্ড্রয়েড সিস্টেমের মেমরির অবস্থা নিরীক্ষণ করে এবং সিস্টেমটিকে গ্রহণযোগ্য স্তরে পারফর্ম করতে ন্যূনতম প্রয়োজনীয় প্রক্রিয়াগুলিকে মেরে উচ্চ মেমরির চাপে প্রতিক্রিয়া দেখায়।
স্মৃতির চাপ সম্পর্কে
সমান্তরালভাবে একাধিক প্রক্রিয়া চলমান একটি অ্যান্ড্রয়েড সিস্টেম এমন পরিস্থিতির সম্মুখীন হতে পারে যখন সিস্টেম মেমরি শেষ হয়ে যায় এবং প্রসেসগুলির জন্য আরও মেমরির অভিজ্ঞতার প্রয়োজন হয় লক্ষণীয় বিলম্ব। মেমরির চাপ , এমন একটি অবস্থা যেখানে সিস্টেমের মেমরির অভাব রয়েছে, এর জন্য Android-এর প্রয়োজন মেমরি মুক্ত করার জন্য (চাপ কমানোর জন্য) গুরুত্বহীন প্রক্রিয়াগুলিকে থ্রটলিং বা হত্যা করে, প্রক্রিয়াগুলিকে ননক্রিটিকাল ক্যাশে করা সংস্থানগুলিকে মুক্ত করার জন্য অনুরোধ করা ইত্যাদি।
ঐতিহাসিকভাবে, অ্যান্ড্রয়েড একটি ইন-কারনেল লো মেমরি কিলার (LMK) ড্রাইভার ব্যবহার করে সিস্টেম মেমরির চাপ নিরীক্ষণ করে, একটি কঠোর প্রক্রিয়া যা হার্ড-কোডেড মানগুলির উপর নির্ভর করে। কার্নেল 4.12 অনুযায়ী, আপস্ট্রিম কার্নেল থেকে LMK ড্রাইভার সরিয়ে দেওয়া হয়েছে এবং ইউজারস্পেস lmkd
মেমরি পর্যবেক্ষণ ও প্রক্রিয়া হত্যার কাজ সম্পাদন করে।
চাপ স্টল তথ্য
Android 10 এবং পরবর্তীতে একটি নতুন lmkd
মোড সমর্থন করে যা মেমরির চাপ সনাক্তকরণের জন্য কার্নেল চাপ স্টল তথ্য (PSI) মনিটর ব্যবহার করে। আপস্ট্রিম কার্নেলের PSI প্যাচসেট (4.9 এবং 4.14 কার্নেলে ব্যাকপোর্ট করা হয়েছে) মেমরির স্বল্পতার ফলে কাজগুলি কতটা বিলম্বিত হয় তা পরিমাপ করে। যেহেতু এই বিলম্বগুলি সরাসরি ব্যবহারকারীর অভিজ্ঞতাকে প্রভাবিত করে, তারা মেমরির চাপের তীব্রতা নির্ধারণের জন্য একটি সুবিধাজনক মেট্রিক উপস্থাপন করে। আপস্ট্রিম কার্নেলের মধ্যে PSI মনিটরও রয়েছে যা বিশেষ সুবিধাপ্রাপ্ত ইউজারস্পেস প্রসেসগুলিকে (যেমন lmkd
) এই বিলম্বগুলির জন্য থ্রেশহোল্ড নির্দিষ্ট করতে এবং থ্রেশহোল্ড লঙ্ঘন হলে কার্নেল থেকে ইভেন্টগুলিতে সদস্যতা নেওয়ার অনুমতি দেয়।
PSI মনিটর বনাম vmpressure সংকেত
যেহেতু vmpressure
সংকেত (মেমরির চাপ সনাক্তকরণের জন্য কার্নেল দ্বারা উত্পন্ন এবং lmkd
দ্বারা ব্যবহৃত) প্রায়শই অনেকগুলি মিথ্যা পজিটিভ অন্তর্ভুক্ত করে, lmkd
অবশ্যই ফিল্টারিং করতে হবে তা নির্ধারণ করতে যে মেমরিটি প্রকৃত চাপের অধীনে রয়েছে কিনা। এর ফলে অপ্রয়োজনীয় lmkd
ওয়েকআপ এবং অতিরিক্ত কম্পিউটেশনাল রিসোর্স ব্যবহার করা হয়। PSI মনিটর ব্যবহার করার ফলে আরও সঠিক মেমরির চাপ সনাক্ত করা যায় এবং ওভারহেড ফিল্টারিং কমিয়ে দেয়।
PSI মনিটর ব্যবহার করে
vmpressure
ইভেন্টের পরিবর্তে PSI মনিটর ব্যবহার করতে, ro.lmk.use_psi
বৈশিষ্ট্য কনফিগার করুন। ডিফল্ট true
, PSI lmkd
এর জন্য মেমরির চাপ সনাক্তকরণের ডিফল্ট প্রক্রিয়া নিরীক্ষণ করে। যেহেতু PSI মনিটরগুলির জন্য কার্নেল সমর্থন প্রয়োজন, কার্নেলে অবশ্যই PSI ব্যাকপোর্ট প্যাচগুলি অন্তর্ভুক্ত করতে হবে এবং PSI সমর্থন সক্রিয় ( CONFIG_PSI=y
) দিয়ে কম্পাইল করতে হবে।
ইন-কারনেল LMK ড্রাইভারের ত্রুটি
Android অনেক সমস্যার কারণে LMK ড্রাইভারকে অবমূল্যায়ন করে, যার মধ্যে রয়েছে:
- লো-র্যাম ডিভাইসগুলিকে আক্রমনাত্মকভাবে টিউন করতে হয়েছিল, এবং তারপরেও বড় ফাইল-ব্যাকড সক্রিয় পেজক্যাশ সহ ওয়ার্কলোডগুলিতে খারাপভাবে কাজ করবে৷ খারাপ পারফরম্যান্সের ফলে থ্র্যাশিং এবং কোন খুন হয়নি।
- LMK কার্নেল ড্রাইভার ফ্রি-মেমরি সীমার উপর নির্ভর করে, মেমরির চাপের উপর ভিত্তি করে কোন স্কেলিং ছাড়াই।
- ডিজাইনের অনমনীয়তার কারণে, অংশীদাররা প্রায়ই ড্রাইভারকে কাস্টমাইজ করে যাতে এটি তাদের ডিভাইসে কাজ করে।
- LMK ড্রাইভার স্ল্যাব সঙ্কুচিত API-এর সাথে যুক্ত ছিল, যা লক্ষ্যবস্তু অনুসন্ধান এবং তাদের হত্যার মতো ভারী অপারেশনের জন্য ডিজাইন করা হয়নি, যা
vmscan
প্রক্রিয়াটিকে ধীর করে দেয়।
ইউজারস্পেস lmkd
lmkd
ইন-কারনেল ড্রাইভারের মতো একই কার্যকারিতা প্রয়োগ করে কিন্তু মেমরির চাপ সনাক্ত ও অনুমান করার জন্য বিদ্যমান কার্নেল প্রক্রিয়া ব্যবহার করে। এই ধরনের মেকানিজমগুলির মধ্যে রয়েছে কার্নেল-জেনারেটেড vmpressure
ইভেন্ট বা প্রেসার স্টল ইনফরমেশন (PSI) মনিটর ব্যবহার করে মেমরির চাপের মাত্রা সম্পর্কে বিজ্ঞপ্তি পেতে, এবং মেমরি cgroup বৈশিষ্ট্যগুলি ব্যবহার করে প্রক্রিয়ার গুরুত্বের উপর ভিত্তি করে প্রতিটি প্রক্রিয়ার জন্য বরাদ্দ করা মেমরি সংস্থানগুলিকে সীমিত করতে।
অ্যান্ড্রয়েড 10 এ ইউজারস্পেস lmkd ব্যবহার করা হচ্ছে
অ্যান্ড্রয়েড 9 এবং পরবর্তীতে, একটি ইন-কার্নেল LMK ড্রাইভার সনাক্ত না হলে ব্যবহারকারীর lmkd
সক্রিয় হয়। যেহেতু lmkd
এর জন্য মেমরি cgroups-এর জন্য কার্নেল সমর্থন প্রয়োজন, কার্নেল নিম্নলিখিত কনফিগারেশন সেটিংসের সাথে কম্পাইল করা আবশ্যক:
CONFIG_ANDROID_LOW_MEMORY_KILLER=n
CONFIG_MEMCG=y
CONFIG_MEMCG_SWAP=y
হত্যার কৌশল
ইউজারস্পেস lmkd
vmpressure
ইভেন্ট বা PSI মনিটর, তাদের তীব্রতা, এবং অদলবদল ব্যবহারের মতো অন্যান্য ইঙ্গিতগুলির উপর ভিত্তি করে হত্যার কৌশল সমর্থন করে। লো-মেমরি এবং হাই-পারফরম্যান্স ডিভাইসের মধ্যে কিল কৌশলগুলি আলাদা:
- কম মেমরির ডিভাইসে, সিস্টেমের অপারেশনের একটি স্বাভাবিক মোড হিসাবে উচ্চ মেমরির চাপ সহ্য করা উচিত।
- উচ্চ-পারফরম্যান্স ডিভাইসগুলিতে, মেমরির চাপকে একটি অস্বাভাবিক পরিস্থিতি হিসাবে দেখা উচিত এবং সামগ্রিক কর্মক্ষমতা প্রভাবিত করার আগে এটি ঠিক করা উচিত।
আপনি ro.config.low_ram
বৈশিষ্ট্য ব্যবহার করে হত্যা কৌশল কনফিগার করতে পারেন। বিস্তারিত জানার জন্য, লো রাম কনফিগারেশন দেখুন।
lmkd
একটি লিগ্যাসি মোডকেও সমর্থন করে যেখানে এটি ইন-কার্নেল LMK ড্রাইভার (অর্থাৎ ফ্রি মেমরি এবং ফাইল ক্যাশে থ্রেশহোল্ড) এর মতো একই কৌশল ব্যবহার করে হত্যার সিদ্ধান্ত নেয়। লিগ্যাসি মোড সক্ষম করতে, ro.lmk.use_minfree_levels
প্রপার্টিটিকে true
সেট করুন।
lmkd কনফিগার করা হচ্ছে
নিম্নলিখিত বৈশিষ্ট্যগুলি ব্যবহার করে একটি নির্দিষ্ট ডিভাইসের জন্য lmkd
কনফিগার করুন।
সম্পত্তি | ব্যবহার করুন | ডিফল্ট |
---|---|---|
ro.config.low_ram | ডিভাইসটি কম RAM বা উচ্চ-পারফরম্যান্স ডিভাইস কিনা তা নির্দিষ্ট করুন। | false |
ro.lmk.use_psi | PSI মনিটর ব্যবহার করুন ( vmpressure ইভেন্টের পরিবর্তে)। | true |
ro.lmk.use_minfree_levels | প্রক্রিয়া হত্যার সিদ্ধান্ত নেওয়ার জন্য বিনামূল্যে মেমরি এবং ফাইল ক্যাশে থ্রেশহোল্ড ব্যবহার করুন (অর্থাৎ, ইন-কারনেল LMK ড্রাইভারের কার্যকারিতার সাথে মেলে)। | false |
ro.lmk.low | নিম্ন vmpressure স্তরে নিহত হওয়ার যোগ্য প্রসেসের জন্য ন্যূনতম oom_adj স্কোর। | 1001 (অক্ষম) |
ro.lmk.medium | মাঝারি vmpressure স্তরে মারা যাওয়ার যোগ্য প্রসেসের জন্য ন্যূনতম oom_adj স্কোর। | 800 (ক্যাশেড বা অপ্রয়োজনীয় পরিষেবা) |
ro.lmk.critical | ন্যূনতম oom_adj স্কোর ক্রিটিক্যাল vmpressure লেভেলে মেরে ফেলার যোগ্য প্রসেসের জন্য। | 0 (যে কোন প্রক্রিয়া) |
ro.lmk.critical_upgrade | জটিল স্তরে আপগ্রেড সক্ষম করুন৷ | false |
ro.lmk.upgrade_pressure | সর্বাধিক mem_pressure যেখানে স্তরটি আপগ্রেড করা হয়েছে কারণ সিস্টেমটি খুব বেশি অদলবদল করছে। | 100 (অক্ষম) |
ro.lmk.downgrade_pressure | ন্যূনতম mem_pressure যেখানে একটি vmpressure ইভেন্ট উপেক্ষা করা হয় কারণ পর্যাপ্ত বিনামূল্যে মেমরি এখনও উপলব্ধ। | 100 (অক্ষম) |
ro.lmk.kill_heaviest_task | সবচেয়ে ভারী যোগ্য কাজ (সর্বোত্তম সিদ্ধান্ত) বনাম যে কোনও যোগ্য কাজ (দ্রুত সিদ্ধান্ত) হত্যা করুন। | true |
ro.lmk.kill_timeout_ms | একটি কিল করার পরে মিলিসেকেন্ডে সময়কাল যখন অতিরিক্ত কিল করা হবে না। | 0 (অক্ষম) |
ro.lmk.debug | lmkd ডিবাগ লগ সক্রিয় করুন। | false |
উদাহরণ ডিভাইস কনফিগারেশন:
PRODUCT_PROPERTY_OVERRIDES += \
ro.lmk.low=1001 \
ro.lmk.medium=800 \
ro.lmk.critical=0 \
ro.lmk.critical_upgrade=false \
ro.lmk.upgrade_pressure=100 \
ro.lmk.downgrade_pressure=100 \
ro.lmk.kill_heaviest_task=true
অ্যান্ড্রয়েড 11 এ ইউজারস্পেস lmkd
Android 11 একটি নতুন হত্যার কৌশল প্রবর্তন করে lmkd
এর উন্নতি করে। হত্যার কৌশলটি অ্যান্ড্রয়েড 10-এ প্রবর্তিত মেমরির চাপ সনাক্তকরণের জন্য একটি PSI প্রক্রিয়া ব্যবহার করে। Android 11-এ lmkd
মেমরি রিসোর্স ব্যবহারের মাত্রা এবং মেমরির অনাহার এবং কর্মক্ষমতা হ্রাস রোধ করার জন্য থ্র্যাশিং অ্যাকাউন্ট। এই হত্যা কৌশলটি পূর্ববর্তী কৌশলগুলিকে প্রতিস্থাপন করে এবং উচ্চ-কর্মক্ষমতা এবং কম-র্যাম (Android Go) উভয় ডিভাইসেই ব্যবহার করা যেতে পারে।
কার্নেল প্রয়োজনীয়তা
Android 11 ডিভাইসের জন্য, lmkd
এর নিম্নলিখিত কার্নেল বৈশিষ্ট্যগুলির প্রয়োজন:
- PSI প্যাচগুলি অন্তর্ভুক্ত করুন এবং PSI সক্ষম করুন (অ্যান্ড্রয়েড সাধারণ কার্নেল 4.9, 4.14 এবং 4.19 এ উপলব্ধ ব্যাকপোর্ট)।
- পিআইডিএফডি সমর্থন প্যাচগুলি অন্তর্ভুক্ত করুন (অ্যান্ড্রয়েড সাধারণ কার্নেল 4.9, 4.14 এবং 4.19 এ উপলব্ধ ব্যাকপোর্ট)।
- কম RAM ডিভাইসের জন্য, মেমরি cgroups অন্তর্ভুক্ত করুন।
কার্নেল অবশ্যই নিম্নলিখিত কনফিগারেশন সেটিংসের সাথে কম্পাইল করা উচিত:
CONFIG_PSI=y
Android 11 এ lmkd কনফিগার করা হচ্ছে
অ্যান্ড্রয়েড 11-এ মেমরি হত্যার কৌশল নীচে তালিকাভুক্ত টিউনিং নব এবং ডিফল্ট সমর্থন করে। এই বৈশিষ্ট্যগুলি উচ্চ-পারফরম্যান্স এবং নিম্ন-র্যাম উভয় ডিভাইসেই কাজ করে।
সম্পত্তি | ব্যবহার করুন | ডিফল্ট | |
---|---|---|---|
উচ্চ পারদর্শিতা | কম RAM | ||
ro.lmk.psi_partial_stall_ms | আংশিক PSI স্টল থ্রেশহোল্ড, মিলিসেকেন্ডে, কম মেমরি বিজ্ঞপ্তি ট্রিগার করার জন্য। যদি ডিভাইসটি মেমরির চাপের বিজ্ঞপ্তিগুলি খুব দেরিতে পায়, তাহলে আগের বিজ্ঞপ্তিগুলিকে ট্রিগার করতে এই মানটি কমিয়ে দিন৷ যদি মেমরির চাপের বিজ্ঞপ্তিগুলি অপ্রয়োজনীয়ভাবে ট্রিগার হয়, তাহলে ডিভাইসটিকে শব্দের প্রতি কম সংবেদনশীল করতে এই মানটি বাড়ান৷ | 70 | 200 |
ro.lmk.psi_complete_stall_ms | সম্পূর্ণ PSI স্টল থ্রেশহোল্ড, মিলিসেকেন্ডে, গুরুত্বপূর্ণ মেমরি বিজ্ঞপ্তিগুলিকে ট্রিগার করার জন্য। যদি ডিভাইসটি গুরুতর মেমরির চাপের বিজ্ঞপ্তিগুলি খুব দেরিতে পায়, তবে আগের বিজ্ঞপ্তিগুলিকে ট্রিগার করতে এই মানটি হ্রাস করুন৷ যদি সমালোচনামূলক মেমরির চাপের বিজ্ঞপ্তিগুলি অপ্রয়োজনীয়ভাবে ট্রিগার হয়, ডিভাইসটিকে শব্দের প্রতি কম সংবেদনশীল করতে এই মানটি বাড়ান৷ | 700 | |
ro.lmk.thrashing_limit | মোট ফাইল-ব্যাকড পেজক্যাশ আকারের শতাংশ হিসাবে ওয়ার্কসেট রিফল্টের সর্বাধিক পরিমাণ। এই মানের উপরে ওয়ার্কিংসেট রিফল্টের অর্থ হল সিস্টেমটি তার পেজক্যাশে থ্র্যাশ করছে বলে মনে করা হয়। মেমরির চাপের সময় ডিভাইসের কর্মক্ষমতা প্রভাবিত হলে, থ্র্যাশিং সীমিত করতে মান কমিয়ে দিন। থ্র্যাশিং কারণে ডিভাইসের কর্মক্ষমতা অপ্রয়োজনীয়ভাবে মারা গেলে, আরও থ্র্যাশ করার জন্য মান বাড়ান। | 100 | 30 |
ro.lmk.thrashing_limit_decay | থ্রেশিং থ্রেশহোল্ড ক্ষয়কে মূল থ্রেশহোল্ডের শতাংশ হিসাবে প্রকাশ করা হয় যা থ্রেশহোল্ড কমাতে ব্যবহৃত হয় যখন সিস্টেম পুনরুদ্ধার হয় না, এমনকি একটি হত্যার পরেও। যদি ক্রমাগত থ্র্যাশিং অপ্রয়োজনীয় হত্যার উত্পাদন করে, মান হ্রাস করুন। যদি একটি হত্যার পরে ক্রমাগত মারধরের প্রতিক্রিয়া খুব ধীর হয়, মান বাড়ান। | 10 | 50 |
ro.lmk.swap_util_max | মোট অদলবদলযোগ্য মেমরির শতাংশ হিসাবে অদলবদল করা মেমরির সর্বাধিক পরিমাণ। যখন অদলবদল করা মেমরি এই সীমার উপরে বৃদ্ধি পায়, তখন এর অর্থ হল সিস্টেমটি তার বেশিরভাগ অদলবদলযোগ্য মেমরি অদলবদল করেছে এবং এখনও চাপের মধ্যে রয়েছে। এটি ঘটতে পারে যখন অ-অদলবদলযোগ্য বরাদ্দগুলি মেমরির চাপ তৈরি করে যা অদলবদল করে উপশম করা যায় না কারণ বেশিরভাগ অদলবদলযোগ্য মেমরি ইতিমধ্যেই অদলবদল হয়ে গেছে। ডিফল্ট মান হল 100, যা কার্যকরভাবে এই চেকটিকে নিষ্ক্রিয় করে। যদি মেমরির চাপের সময় ডিভাইসের কর্মক্ষমতা প্রভাবিত হয় যখন সোয়াপ ব্যবহার বেশি হয় এবং বিনামূল্যের সোয়াপ স্তর ro.lmk.swap_free_low_percentage এ না নেমে যায়, তাহলে সোয়াপ ব্যবহার সীমিত করতে মান হ্রাস করুন। | 100 | 100 |
নিম্নলিখিত পুরানো টিউনিং নবগুলিও নতুন হত্যা কৌশলের সাথে কাজ করে।
সম্পত্তি | ব্যবহার করুন | ডিফল্ট | |
---|---|---|---|
উচ্চ পারদর্শিতা | কম RAM | ||
ro.lmk.swap_free_low_percentage | মোট অদলবদল স্থানের শতাংশ হিসাবে বিনামূল্যে অদলবদলের স্তর। 'lmkd' এই মানটিকে একটি থ্রেশহোল্ড হিসাবে ব্যবহার করে যখন সিস্টেমটিকে সোয়াপ স্পেস ক্ষুধার্ত হিসাবে বিবেচনা করতে হবে। অদলবদলে অনেক বেশি জায়গা থাকার সময় যদি `lmkd` মেরে ফেলে, শতকরা হার কমিয়ে দিন। যদি `lmkd` হত্যা অনেক দেরিতে হয়, OOM হত্যাকাণ্ড ঘটতে দেয়, শতকরা হার বাড়ান। | 20 | 10 |
ro.lmk.debug | এটি `lmkd` ডিবাগ লগ সক্রিয় করে। টিউন করার সময় ডিবাগ সক্ষম করুন। | false |