데이터 베이스 MySQL 튜토리얼 vm.swappiness=0在最新内核中可能会OOM,MySQL被意外kill

vm.swappiness=0在最新内核中可能会OOM,MySQL被意外kill

Jun 07, 2016 pm 04:41 PM
oom 핵심 최신

请使用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 [2.6.32-303.el6]

...

- [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/

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Ubuntu 22.04에 Linux 커널을 설치하는 방법 자세한 튜토리얼! Ubuntu 22.04에 Linux 커널을 설치하는 방법 자세한 튜토리얼! Mar 01, 2024 pm 10:34 PM

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

Linux 커널 시작 순서 수정 Linux 커널 시작 순서 수정 Feb 23, 2024 pm 10:22 PM

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을 발견하면 어떻게 문제를 해결해야 합니까? 어떻게 해결하나요? 어떤 옵션이 있나요? 특정 그룹과의 인터뷰: 온라인에서 OOM을 발견하면 어떻게 문제를 해결해야 합니까? 어떻게 해결하나요? 어떤 옵션이 있나요? Aug 23, 2023 pm 02:34 PM

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

면접관: 온라인에서 OOM을 접하게 된다면 어떻게 해결하나요? 면접관: 온라인에서 OOM을 접하게 된다면 어떻게 해결하나요? Aug 17, 2023 pm 04:38 PM

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

Snapdragon 프로세서 순위의 최신 목록 Snapdragon 프로세서 순위의 최신 목록 Mar 22, 2024 am 11:33 AM

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

Android 시스템은 Linux 커널을 기반으로 합니까? Android 시스템은 Linux 커널을 기반으로 합니까? Mar 14, 2024 pm 03:12 PM

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

리눅스 커널 주요 기능 분석 및 분석 리눅스 커널 주요 기능 분석 및 분석 Mar 14, 2024 am 11:27 AM

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

Linux 커널 내부에서 사용되는 프로그래밍 언어 살펴보기 Linux 커널 내부에서 사용되는 프로그래밍 언어 살펴보기 Mar 20, 2024 am 08:06 AM

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

See all articles