search
HomeDatabaseMysql TutorialMySQL OOM Series 3: Get rid of the bad luck of MySQL being killed_MySQL

In the previous two chapters, we analyzed the Linux memory allocation strategy and Linux solved the risk caused by "overbooking" by using the OOM_Killer mechanism. MySQL, like other applications, can also be overbooked within the scope allowed by the operating system. , Most people understand that Innodb_buffer_pool must be smaller than the actual physical memory, otherwise MySQL will fail to start. In fact, this is a misunderstanding. This is not controlled by the MySQL layer. This is controlled by the operating system (OS) layer. The aforementioned /proc/sys/overcommit_memory controls whether the OS allows "overbooking". If "overbooking" is allowed, Innodb_buffer_pool can far exceed the actual memory space size, but this part of the space is not used. We can do a small experiment, see the picture below:

MySQL's Innodb_buffer_pool is set to 5G, but the actual memory is only 3G.
Having said so much, let’s get back to the topic and return to the issue we first mentioned about the RDS instance being killed by the OS. We also mentioned earlier that once the available memory of the instance is insufficient, MySQL will generally become the first choice of OOM_Killer. There are two issues involved here:

1. Why is there insufficient memory?
2. How to get MySQL out of the bad luck of being killed?
First let's look at the first question. There are many reasons for the problem of insufficient memory, but there are mainly two aspects. The first is that there is a problem with MySQL's own memory planning. The second is that servers that generally deploy MySQL will deploy a lot of monitoring or scheduled task scripts, and these scripts often lack necessary memory restrictions, resulting in occupying a large amount of memory during peak periods, triggering the Linux OOM_Killer mechanism, and MySQL is innocent sacrificed.
So how can we get MySQL out of the bad luck of being killed? The root cause of MySQL being killed lies in the overbooked memory allocation mechanism of Linux. As mentioned earlier, as long as this overbooked mechanism exists, it is impossible to completely avoid the risk of a certain application being killed. To prevent MySQL from being killed, the operating system can only be prohibited from allocating memory beyond the actual memory space. But as we mentioned before, we do not recommend this for servers where MySQL is deployed, because a lot of MySQL’s memory has just been applied for and is not used immediately. Once the OS prohibits overbooking, this will not only affect MySQL’s own memory The planning puts forward more stringent requirements, and there is also the problem of insufficient memory utilization. At the same time, the private memory of each MySQL connection is dynamically allocated. If it is not allocated, it will directly cause the server to crash, which will also increase the risk of MySQL crash.
Since it is limited by the operating system and cannot completely avoid being killed, we can only try to reduce the probability of MySQL being killed. I think we can do at least the following 3 things:


1) Reasonably plan the memory usage of MySQL.
2) Adjust the OOM_adj parameter to lower the priority of MySQL being locked by OOM_Killer.
3) Strengthen memory monitoring and alarming. Once alarmed, the DBA should quickly intervene and kill some connections that occupy more memory.

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
How do you alter a table in MySQL using the ALTER TABLE statement?How do you alter a table in MySQL using the ALTER TABLE statement?Mar 19, 2025 pm 03:51 PM

The article discusses using MySQL's ALTER TABLE statement to modify tables, including adding/dropping columns, renaming tables/columns, and changing column data types.

How do I configure SSL/TLS encryption for MySQL connections?How do I configure SSL/TLS encryption for MySQL connections?Mar 18, 2025 pm 12:01 PM

Article discusses configuring SSL/TLS encryption for MySQL, including certificate generation and verification. Main issue is using self-signed certificates' security implications.[Character count: 159]

How do you handle large datasets in MySQL?How do you handle large datasets in MySQL?Mar 21, 2025 pm 12:15 PM

Article discusses strategies for handling large datasets in MySQL, including partitioning, sharding, indexing, and query optimization.

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?Mar 21, 2025 pm 06:28 PM

Article discusses popular MySQL GUI tools like MySQL Workbench and phpMyAdmin, comparing their features and suitability for beginners and advanced users.[159 characters]

How do you drop a table in MySQL using the DROP TABLE statement?How do you drop a table in MySQL using the DROP TABLE statement?Mar 19, 2025 pm 03:52 PM

The article discusses dropping tables in MySQL using the DROP TABLE statement, emphasizing precautions and risks. It highlights that the action is irreversible without backups, detailing recovery methods and potential production environment hazards.

How do you represent relationships using foreign keys?How do you represent relationships using foreign keys?Mar 19, 2025 pm 03:48 PM

Article discusses using foreign keys to represent relationships in databases, focusing on best practices, data integrity, and common pitfalls to avoid.

How do you create indexes on JSON columns?How do you create indexes on JSON columns?Mar 21, 2025 pm 12:13 PM

The article discusses creating indexes on JSON columns in various databases like PostgreSQL, MySQL, and MongoDB to enhance query performance. It explains the syntax and benefits of indexing specific JSON paths, and lists supported database systems.

How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)?How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)?Mar 18, 2025 pm 12:00 PM

Article discusses securing MySQL against SQL injection and brute-force attacks using prepared statements, input validation, and strong password policies.(159 characters)

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)