컴퓨터/노트북/인터넷
IT 컴퓨터 기기를 좋아하는 사람들의 모임방
MySQL/MariaDB Memory 모니터링
- Version : MySQL 5.7.21, Ubuntu 16.0.4
Memory 사용률은 모든 운영체제에서 중요한 모니터링 지표이다. 다양한 어플리케이션이 서버에서 실행되면서 실제 물리메모리를 초과하는 메모리 요구가 발생할 수 있기 때문에 메모리 모니터링도 중요하다. 실제 데이터베이스의 경우 메모리가 부족하여 성능저하가 크게 발생하는 경우가 많다.
아래 명령어는 Unbuntu Linux에서 5초 간격으로 메모리 사용량을 확인하는 명령이다.
watch -n 5 free –m |
리눅스는 메모리의 효율적인 운영을 위해 전체 메모리에서 미리 Buffers + Cached 값을 자동으로 할당해 놓는다. 만일 어플리케이션에서 메모리가 필요할 경우 Cached에 할당된 메모리를 자동으로 반환해 어플리케이션에 할당한다.
MySQL 서버는 다양한 종류의 메모리 버퍼(메모리 캐시)를 사용한다. 사용영역에 따라 크게 전역과 지역으로 나눌 수 있다.
- MySQL/MariaDB 아키텍처 – 메모리 할당 및 사용 구조 : http://sqlmvp.kr/220404814981
전역 메모리 (모든 커넥션 또는 스레드에서 공유) |
지역메모리 (세션별로 할당, 공유하지 않음) |
|
|
전체 메모리 사용량을 예상하여 할당하려면 아래와 같은 공식을 사용한다.
전역 메모리 사용량 합 + (지역적 메모리 사용량 합 X 최대 동시 커넥션 수) |
만약 물리 메모리 대비 InnoDB 버퍼풀 크기 비율을 과도하게 높게 하였을때 활성 커넥션(Active DB Connections) 증가로 세션 단위의 메모리 사용량이 증가한다면 MySQL 서버가 사용하는 전체 메모리는 물리메모리를 초과할 수 있으며 서버의 성능저하로 이어질 수 있다. 따라서 아래와 같은 가이드를 제공하여 성능 저하를 예방할 수 있다.
- 운영체제가 사용하는 적정 메모리 용량을 제외한 Buffer pool 할당
- MySQL 서버에서 제공하는 Max Connection 수 제한
- Max Connection 수 만큼 세션이 증가할 수 있으므로 세션별로 사용해야 하는 메모리 사용량 제한
- 물리 메모리를 초과하지 않는 범위에서 MySQL 서버가 전역적으로 사용해야하는 메모리 영역에 대한 최대 사용랑 제한
메모리 관련 설정을 할 때 메모리 사용량에 영향을 줄 수 있는 변수는 약간의 유휴 메모리를 유지될 수 있게 설정하는 것을 권장한다.
- MySQL/MariaDB Memory 관련 설정 변수 : http://sqlmvp.kr/220365937569
Swap 메모리가 빈번한 경우 서버에서 실행되는 어플리케이션이 메모리를 적절하게 사용하지 못하거나 물리 메모리가 부족하다는 것을 의미하기 때문에 Swap 지수가 0보다 큰 경우 어느 어플리케이션이 메모리를 많이 사용하는지 확인이 필요하다.
[참고자료]
- How MySQL Uses Memory : https://dev.mysql.com/doc/refman/5.7/en/memory-use.html
2018-03-27 / 강성욱 / http://sqlmvp.kr / http://sqlangeles.com
MySQL, MariaDB, linux, Memory 모니터링, watch, InnoDB Buffer pool, MySQL 메모리 사용량, 전역 메모리, 지역 메모리, 세션 메모리, Max connection
컴퓨터/노트북/인터넷
IT 컴퓨터 기기를 좋아하는 사람들의 모임방
-
구글 최신 뉴스
날짜2024.12.12 카테고리뉴스 읽음1385 -
아 진짜 요새 SKT 해킹 뭐시기 때문에 신경 쓰여 죽겠어 ㅠㅠ
날짜2025.05.20 카테고리일반 읽음237 -
사랑LOVE 포인트 만렙! 도전
날짜2025.03.19 카테고리 읽음4669 -
🚨(뉴비필독) 전체공지 & 포인트안내
날짜2024.11.04 카테고리 읽음25850 -
URL만 붙여넣으면 끝! 임베드 기능
날짜2025.01.21 카테고리 읽음20432 -
Intel 12세대 i3-12100YouTube 10비트 HDR 8K60 AV1 비디오를 원활하게 재생가능?
날짜2024.11.10 조회수4540 -
블루투스 헤드셋 질문좀~
날짜2021.01.31 조회수49 -
e4000이랑 560s랑 음질차이
날짜2021.01.28 조회수70 -
未检测到我的手机MTP。
날짜2019.12.24 조회수29 -
amd 라이젠 1700 > 인텔 i5 12400f cpu 변경후 드라이브 오류
날짜2022.06.14 조회수1122 -
윈도우 11 에러 중에 이런 종류가 있나요?
날짜2022.06.14 조회수1085 -
마소계정에 정품인증
날짜2022.06.14 조회수420 -
4k나 1080p 동영상 보면 렉이 걸리는데...
날짜2022.06.14 조회수482 -
제가쓰던 놋북 윈도우가 리테일이래요 그러니까 fpp 윈도우라는거 맞죠??
날짜2022.06.14 조회수401 -
윈도우 10 왜 버벅일까요..?
날짜2022.06.14 조회수348 -
오피스 정품 판매 맞을까요?
날짜2022.06.14 조회수169 -
윈도우11 더 많은 옵션 항상사용하는 방법
날짜2022.06.09 조회수262 -
윈도우 11 22H2 RTM 빌드 확정됨
날짜2022.05.30 조회수223 -
해킹 대회에서 윈도우 11의 취약점 6개가 발견됨
날짜2022.05.30 조회수235 -
ProtonMail, 통합 브랜드로 다양한 서비스를 제공
날짜2022.05.30 조회수185 -
가상머신에 윈도우95 설치하기
날짜2022.04.22 조회수630 -
구글 크롬 100 버전 공개
날짜2022.04.04 조회수839 -
윈도우 11+다이렉트스토리지, 게임 로딩 시 CPU 부하가 최대 40% 감소
날짜2022.04.04 조회수708 -
애플, 위조된 법적 증명에 속아 사용자 데이터를 제공?
날짜2022.04.04 조회수639 -
윈도우 탐색기 대체 대안 프로그램 8가지
날짜2022.04.04 조회수904 -
인터넷은 어떻게 작동되는지 알아보자
날짜2022.04.02 조회수675 -
크롬 취약점 발견 Chrome 업데이트 빨리 해야
날짜2022.03.30 조회수764 -
GPU-Z, 인텔 아크 알케미스트 그래픽 지원
날짜2022.03.26 조회수147 -
아프리카 TV가 트위치보다 데이터를 훨씬 많이 쓰는군요
날짜2022.03.26 조회수224 -
애플, 미국 애리조나 주에서 월렛에 신분증 기능 제공
날짜2022.03.26 조회수151 -
macOS 12.3에서 외장 모니터 연결 문제, 게임 패드 연결 문제
날짜2022.03.26 조회수164 -
비트코인 오브 아메리카, ATM에서 도지코인을 취급
날짜2022.03.26 조회수152 -
1990년대 중후반에 나온 PowerVR PC GPU의 소스 코드 공개
날짜2022.03.26 조회수158 -
NVIDIA, 삼성, MS를 해킹한 Lapsus$. 알고보니 10대 소년이 주범?
날짜2022.03.26 조회수159 -
통신사 직원 수십억원 갖고 잠적
날짜2022.03.26 조회수364