কম মেমরি কিলার ডেমন

অ্যান্ড্রয়েড লো মেমরি কিলার ডেমন ( 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