vm.swappiness=0在最新内核中可能会OOM,MySQL被意外kill
请使用RHEL/CentOS 6.4及更新版本内核的MySQL同志们注意,vm.swappiness = 0的默认行为修改了,如果继续设置vm.swappiness = 0,有可能导致系统内存溢出,从而导致MySQL被意外kill掉。 在之前的《LINUX上MYSQL优化三板斧》中,我们建议大家把 vm.swappiness
请使用RHEL/CentOS 6.4及更新版本内核的MySQL同志们注意,vm.swappiness = 0的默认行为修改了,如果继续设置vm.swappiness = 0,有可能导致系统内存溢出,从而导致MySQL被意外kill掉。
在之前的《LINUX上MYSQL优化三板斧》中,我们建议大家把 vm.swappiness = 0 设置好。来尽量避免MySQL的服务器内存被交换出去。这样Linux在把内存交换出去时更偏向于将cache页交换出去,而不是将inactive页交换出去。详细描述请参考:http://www.woqutech.com/?p=1200。
经常有人会问, vm.swappiness = 0会不会导致Linux在有swap空间的时候也不交换出去,从而导致内存溢出(OOM)。参照《LINUX上MYSQL优化三板斧》介绍,我们知道,这个值只是一个Linux在判断是否交换内存(swap)的一个“倾向”参考值,而并不是说,设置为0以后,Linux就完全不会使用内存交换空间。
但是,在较新的内核中(2.6.32-303.el6及以后),vm.swappiness = 0 的默认行为修改掉了,这个说法不再成立。设置该参数vm.swappiess=0,有可能导致MySQL数据库所在的系统出现内存溢出。一般来说,MySQL数据库占用的内存是整个服务器中最大的,根据Linux的策略,它会会首先把MySQL给Kill掉(调整?/proc/(pidof -s mysqld)/oom_adj可以改变OOM时kill的优先级),从而导致应用故障等。
这个修改是在内核3.5-rc1中提交的,并且合并到了2.6.32-303.el6及之后的各个版本。先让我们来看看这个patch:
http://gitorious.ti.com/ti-linux-kernel/ti-linux-kernel/commit/fe35004fbf9eaf67482b074a2e032abb9c89b1dd?format=patch
From fe35004fbf9eaf67482b074a2e032abb9c89b1dd Mon Sep 17 00:00:00 2001
From: Satoru Moriya
Date: Tue, 29 May 2012 15:06:47 -0700
Subject: [PATCH] mm: avoid swapping out with swappiness==0
Sometimes we'd like to avoid swapping out anonymous memory. ?In
particular, avoid swapping out pages of important process or process
groups while there is a reasonable amount of pagecache on RAM so that we
can satisfy our customers' requirements.
OTOH, we can control how aggressive the kernel will swap memory pages with
/proc/sys/vm/swappiness for global and
/sys/fs/cgroup/memory/memory.swappiness for each memcg.
But with current reclaim implementation, the kernel may swap out even if
we set swappiness=0 and there is pagecache in RAM.
This patch changes the behavior with swappiness==0. ?If we set
swappiness==0, the kernel does not swap out completely (for global reclaim
until the amount of free pages and filebacked pages in a zone has been
reduced to something very very small (nr_free + nr_filebacked
watermark)).
Signed-off-by: Satoru Moriya
Acked-by: Minchan Kim
Reviewed-by: Rik van Riel
Acked-by: Jerome Marchand
Signed-off-by: Andrew Morton
Signed-off-by: Linus Torvalds
---
?mm/vmscan.c | ? ?6 +++---
?1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/mm/vmscan.c b/mm/vmscan.c
index 67a4fd4..ee97530 100644
--- a/mm/vmscan.c
+++ b/mm/vmscan.c
@@ -1761,10 +1761,10 @@ static void get_scan_count(struct mem_cgroup_zone *mz, struct scan_control *sc,
?? * proportional to the fraction of recently scanned pages on
?? * each list that were recently referenced and in active use.
?? */
-?? ap = (anon_prio + 1) * (reclaim_stat->recent_scanned[0] + 1);
+?? ap = anon_prio * (reclaim_stat->recent_scanned[0] + 1);
?? ap /= reclaim_stat->recent_rotated[0] + 1;
-?? fp = (file_prio + 1) * (reclaim_stat->recent_scanned[1] + 1);
+?? fp = file_prio * (reclaim_stat->recent_scanned[1] + 1);
?? fp /= reclaim_stat->recent_rotated[1] + 1;
?? spin_unlock_irq(&mz->zone->lru_lock);
@@ -1777,7 +1777,7 @@ out:
????? unsigned long scan;
????? scan = zone_nr_lru_pages(mz, lru);
-????? if (priority || noswap) {
+????? if (priority || noswap || !vmscan_swappiness(mz, sc)) {
????????? scan >>= priority;
????????? if (!scan && force_scan)
???????????? scan = SWAP_CLUSTER_MAX;
--?
1.7.5
就像Satoru Moriya所说的那样,在之前的版本中,就算我们设置了swappiness=0并且RAM中还有pagecache,内核也可能会交换出部分匿名内存页。而为了“满足用户的需求”,这个patch修改了swappiness=0的行为,如果你设置swappiness=0,那么只有在(nr_free + nr_filebacked
在2.6.32-303.el6 RHEL/CentOS及更新版本的内核中,该patch就已经被合并进来:
* Mon Aug 27 2012 Jarod Wilson
...
- [mm] avoid swapping out with swappiness==0 (Satoru Moriya) [787885]
其他分发版本的Linux(比如Debian,Ubuntu)的版本中,请各位自己查阅一下,看看时候已经合并该patch。
RHEL/CentOS 6.3的内核版本是2.6.32-279,而RHEL/CentOS 6.4的内核为2.6.32-358,从这个版本开始,swappiness的行为就已经修改了,使用这个版本及之后版本的同志们需要特别注意一下。
解决的办法其实也很简单,
1、尽量保证Linux操作系统还有足够的内存
2、最新的内核,建议把vm.swappiness设置1
3、考虑设置 /proc/(pidof -s mysqld)/oom_adj为较小的值来尽量避免MySQL由于内存不足而被关闭。
参考:
https://github.com/torvalds/linux/blob/master/mm/vmscan.c
http://gitorious.ti.com/ti-linux-kernel/ti-linux-kernel/commit/fe35004fbf9eaf67482b074a2e032abb9c89b1dd?format=patch
http://www.mysqlperformanceblog.com/2014/04/28/oom-relation-vm-swappiness0-new-kernel/
原文地址:vm.swappiness=0在最新内核中可能会OOM,MySQL被意外kill, 感谢原作者分享。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Ubuntu22.04에 Linux 커널을 설치하려면 다음 단계를 수행할 수 있습니다. 시스템 업데이트: 먼저 Ubuntu 시스템이 최신인지 확인하고 다음 명령을 실행하여 시스템 패키지를 업데이트합니다. sudoaptupdatesudoaptupgrade 커널 파일 다운로드: 공식 Linux 커널 웹사이트()에서 필수 커널 버전을 다운로드하세요. 안정적인 버전을 선택하고 소스 코드 파일(.tar.gz 또는 .tar.xz 확장자 포함)을 다운로드합니다. 예: wget 파일 압축 풀기: 다운로드한 커널 소스 코드 파일의 압축을 풀려면 다음 명령을 사용하십시오: tar-xflinux-5.14 .tar.xz 설치 빌드 종속성: 커널을 빌드하는 데 필요한 도구 및 종속성을 설치합니다. 실행하다

Linux의 커널 시작 순서 수정 1. RHEL6/CentOS6의 커널 시작 순서를 수정하려면 /etc/grub.conf 파일을 확인하여 시스템 커널 상황을 확인하세요. 문서에 따르면 시스템에는 2.6.32-573.18.1.el6.x86_64 및 2.6.32-431.23.3.el6.x86_64라는 두 가지 커널 버전이 있습니다. 커널 버전은 위에서 아래로 나열됩니다. grub.conf 파일에서 기본 매개변수를 조정하여 시스템이 시작될 때 사용할 커널 버전을 결정할 수 있습니다. 기본값은 0입니다. 이는 시스템이 최신 커널 버전을 부팅한다는 의미입니다. 값 0은 grub.conf 파일에 나열된 첫 번째 내용에 해당합니다.

OOM은 코드나 JVM 매개변수 구성으로 인해 프로그램에 취약점이 있음을 의미합니다. 이 기사에서는 Java 프로세스가 OOM을 트리거할 때 문제를 해결하는 방법에 대해 독자에게 설명합니다.

OOM은 우리 개발자들이 가장 두려워하는 문제 중 하나라고 할 수 있으며, 그 원인은 기본적으로 코드나 JVM 매개변수 구성에 의해 발생합니다. 이 기사에서는 Java 프로세스가 OOM을 트리거할 때 문제를 해결하는 방법에 대해 독자에게 설명합니다.

Snapdragon 프로세서는 뛰어난 성능과 안정적인 성능으로 항상 폭넓은 인정을 받아 왔으며 휴대폰, 태블릿 등 모바일 장치에서 선호되는 프로세서 중 하나입니다. 지속적인 기술 개발로 Snapdragon 프로세서도 지속적으로 업데이트되고 있으며 각각의 새로운 세대의 제품이 광범위한 관심을 끌 것입니다. 최근 한 권위 있는 기관에서 최신 Snapdragon 프로세서 순위 목록을 발표하여 사람들이 각 프로세서의 성능을 보다 명확하게 이해할 수 있도록 했습니다. 우선, 목록에 따르면 Snapdragon 8 시리즈 프로세서는 항상 가장 강력한 프로세서 중 하나였으며 시장에서 높은 인기를 얻었습니다. 최신호

Android 시스템은 Linux 커널을 기반으로 합니까? 안드로이드 시스템은 세계에서 가장 널리 사용되는 모바일 운영체제 중 하나로 늘 리눅스 커널을 기반으로 개발됐다고 알려져 왔다. 그러나 실제 상황은 어떠한가? 이 문제를 살펴보겠습니다. 먼저 리눅스 커널을 이해해보자. 오픈 소스 운영 체제 커널인 Linux 커널은 1991년 Linus Torvalds에 의해 처음 출시되었습니다. 이는 다음을 포함한 많은 운영 체제에 대한 좋은 기반을 제공합니다.

Linux 커널 주요 기능 분석 및 분석 Linux 커널은 주요 기능이 중요한 역할을 하는 크고 복잡한 시스템이며, 마지막으로 다양한 하위 시스템, 드라이버 및 커널 모듈의 초기화를 담당합니다. 전체 운영 체제를 시작합니다. 이 기사에서는 Linux 커널의 주요 기능을 구문 분석하고 특정 코드 예제를 통해 주요 기능과 실행 흐름을 보여줍니다. Linux 커널에서 main 함수의 진입점은 init/main.c 파일의 start_k입니다.

제목: Linux 커널의 맨 아래에 사용되는 프로그래밍 언어 탐색 Linux 커널은 안정적이고 신뢰할 수 있는 오픈 소스 운영 체제 커널로서 컴퓨터 분야에서 광범위한 응용 프로그램을 보유하고 있습니다. Linux 커널을 심층적으로 이해하려면 기본 수준에서 사용되는 프로그래밍 언어를 포함해야 합니다. 실제로 Linux 커널은 주로 C 언어로 작성되었습니다. C 언어는 효율적이고 유연하며 유지 관리가 쉬운 프로그래밍 언어로 운영 체제 개발에 매우 적합합니다. 이 기사에서는 자세한 관점에서 Linux 커널의 하단을 살펴보겠습니다.
