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

অ্যান্ড্রয়েড লো মেমরি কিলার ডেমন ( lmkd ) প্রসেস একটি চলমান অ্যান্ড্রয়েড সিস্টেমের মেমরি স্টেট নিরীক্ষণ করে এবং সিস্টেমটিকে গ্রহণযোগ্য মাত্রায় পারফর্ম করতে ন্যূনতম প্রয়োজনীয় প্রক্রিয়াগুলিকে মেরে উচ্চ মেমরির চাপে প্রতিক্রিয়া দেখায়।

স্মৃতির চাপ সম্পর্কে

সমান্তরালভাবে একাধিক প্রক্রিয়া চলমান একটি অ্যান্ড্রয়েড সিস্টেম এমন পরিস্থিতির সম্মুখীন হতে পারে যখন সিস্টেম মেমরি শেষ হয়ে যায় এবং প্রসেসগুলির জন্য আরও মেমরির অভিজ্ঞতার প্রয়োজন হয় লক্ষণীয় বিলম্ব। মেমরির চাপ , এমন একটি অবস্থা যেখানে সিস্টেমের মেমরির অভাব রয়েছে, এর জন্য Android-এর প্রয়োজন মেমরি মুক্ত করার জন্য (চাপ কমানোর জন্য) গুরুত্বহীন প্রক্রিয়াগুলিকে থ্রটলিং বা হত্যা করে, প্রক্রিয়াগুলিকে ননক্রিটিক্যাল ক্যাশেড রিসোর্স মুক্ত করার জন্য অনুরোধ করা ইত্যাদি।

ঐতিহাসিকভাবে, অ্যান্ড্রয়েড একটি ইন-কারনেল লো মেমরি কিলার (LMK) ড্রাইভার ব্যবহার করে সিস্টেম মেমরির চাপ নিরীক্ষণ করে, একটি কঠোর প্রক্রিয়া যা হার্ড-কোডেড মানগুলির উপর নির্ভর করে। কার্নেল 4.12 অনুযায়ী, আপস্ট্রিম কার্নেল থেকে LMK ড্রাইভার অপসারণ করা হয়েছে এবং userspace 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

userpace lmkd ইন-কারনেল ড্রাইভারের মতো একই কার্যকারিতা প্রয়োগ করে কিন্তু মেমরির চাপ সনাক্ত ও অনুমান করার জন্য বিদ্যমান কার্নেল প্রক্রিয়া ব্যবহার করে। মেমরির চাপের মাত্রা সম্পর্কে বিজ্ঞপ্তি পেতে কার্নেল-জেনারেটেড vmpressure ইভেন্ট বা প্রেসার স্টল ইনফরমেশন (PSI) মনিটর ব্যবহার করা এবং প্রক্রিয়া গুরুত্বের উপর ভিত্তি করে প্রতিটি প্রক্রিয়ার জন্য বরাদ্দ করা মেমরি সংস্থানগুলিকে সীমিত করার জন্য মেমরি cgroup বৈশিষ্ট্যগুলি ব্যবহার করা অন্তর্ভুক্ত।

অ্যান্ড্রয়েড 10 এ ইউজারস্পেস lmkd ব্যবহার করা হচ্ছে

অ্যান্ড্রয়েড 9 এবং পরবর্তীতে, যদি একটি ইন-কার্নেল LMK ড্রাইভার সনাক্ত না করা হয় তবে ইউজারস্পেস lmkd সক্রিয় হয়। যেহেতু userpace lmkd এর মেমরি cgroups-এর জন্য কার্নেল সমর্থন প্রয়োজন, কার্নেল নিম্নলিখিত কনফিগারেশন সেটিংসের সাথে কম্পাইল করা আবশ্যক:

CONFIG_ANDROID_LOW_MEMORY_KILLER=n
CONFIG_MEMCG=y
CONFIG_MEMCG_SWAP=y

হত্যার কৌশল

ইউজারস্পেস lmkd vmpressure ইভেন্ট বা PSI মনিটর, তাদের তীব্রতা, এবং অদলবদল ব্যবহারের মতো অন্যান্য ইঙ্গিতগুলির উপর ভিত্তি করে হত্যার কৌশল সমর্থন করে। লো-মেমরি এবং উচ্চ-পারফরম্যান্স ডিভাইসের মধ্যে হত্যার কৌশলগুলি আলাদা:

  • কম মেমরির ডিভাইসে, সিস্টেমটিকে অপারেশনের একটি স্বাভাবিক মোড হিসাবে উচ্চ মেমরির চাপ সহ্য করা উচিত।
  • উচ্চ-পারফরম্যান্স ডিভাইসগুলিতে, মেমরির চাপকে একটি অস্বাভাবিক পরিস্থিতি হিসাবে দেখা উচিত এবং সামগ্রিক কর্মক্ষমতা প্রভাবিত করার আগে এটি ঠিক করা উচিত।

আপনি ro.config.low_ram বৈশিষ্ট্য ব্যবহার করে হত্যা কৌশল কনফিগার করতে পারেন। বিস্তারিত জানার জন্য, নিম্ন র‍্যাম কনফিগারেশন দেখুন।

Userspace 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

অ্যান্ড্রয়েড 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