====== Загальна інфо ====== Керуванням ОЗП займається **ядро Linux** (kernel), а саме його частина - MMU (Memory Management Unit). Програми та процеси не мають доступу до фізичних пристроїв (планок в материнці), саме Ядро надає їм доступ до них. Надає віртуальний адресний простір для кожного процесу. Оперативна памʼять працює завжди на повну. Тут діє умовне правило Linux: **вільна памʼять - марна памʼять. ** === Linux використовує ОЗП так: === - **Used**: памʼять яку реально зайняли програми (браузери, сервіси, веб-сервери). - **Buffers/Cache:** кешування * Ядро бере "вільну" памʼять і завантажує туди дані з диска, до яких часто звертається користувач/служба. * Якщо програмі знадобиться додаткова памʼять, вона миттєво візьметься з **Cache** та віддасть її цій програмі. * Саме тому відбувається ситуація, наприклад: в системі 16ГБ памʼяті, під програми зайнято 4ГБ, а 12ГБ пішло під кеш. Це добре. - **SWAP (розділ підкачки або файл підкачки): ** це місце на диску (hdd/sdd), яке ядро використовує як **продовження оперативної памʼяті.** \\ Навіщо він потрібен? * **Аварійний запас:** Коли RAM закінчується, ядро переміщує туди сторінки пам'яті, які використовуються рідко (анонімні сторінки), звільняючи місце в швидкій RAM для активних процесів. * **Гібернація:** В Debian або в інших системах, якщо ви використовуєте ноутбук, вміст RAM записується в Swap при гібернації. === Параметр vm.swappiness === Це налаштування (від 0 до 100), яке каже ядру, як агресивно використовувати Swap. * У Debian/Ubuntu за замовчуванням: **60**. * Це означає, що ядро почне скидати дані в swap ще до того, як RAM заповниться на 100%, щоб зберегти місце для дискового кешу (файлових операцій). * Для серверів баз даних часто ставлять ''swappiness = 1'' або ''10'', щоб максимально використовувати швидку RAM і не чіпати повільний диск.** Це ВАЖЛИВО!** === Що відбувається коли оперативна памʼять в 100%? === Це критична ситуація, яка може привести до повної зупинки системи. * **Thrashing (Пробуксовка):** Спочатку система починає "гальмувати". Ядро панічно намагається звільнити пам'ять: скидає кеші, вивантажує дані в Swap, завантажує назад. Диск працює на 100%, процесор чекає даних (iowait). Система може перестати реагувати на клавіатуру та SSH. * **Прихід OOM Killer:** Коли фізична пам'ять забита і Swap теж забитий (або відсутній), ядро розуміє, що далі працювати неможливо. Тоді воно викликає механізм **Out of Memory Killer (OOM Killer)**. == OOM Killer ( Out-Of-Memory Killer): == Це функція ядра, яка виконує роль "кіллера" процесів щоб підняти систему. Має спеціальну систему підрахунку пріоритетності або підрахунку балів (**OOM Score**). Тобто він не "вбиває" будь який процес, а спочатку підраховує **OOM Score ** для кожного процесу. * Критичний: той хто займає більше памʼяті * Імунітет: системні процеси (sshd, init). * Є шанс: у тих хто працює довго, навідмінну від тих, хто запустився нещодавно і "зʼїв" усю памʼять. Ви можете побачити цей рахунок у файлі: ''/proc//oom_score''. У логах (''/var/log/syslog'' або ''dmesg'') це виглядає так: ''Out of memory: Kill process 1234 (mysqld) score 950 or sacrifice child''