본문 바로가기

컴퓨터/노트북/인터넷

IT 컴퓨터 기기를 좋아하는 사람들의 모임방

🕰️ 2019.02.05 07:39
MySQL Memory 튜닝설명 글
조회 수 334 추천 수 0 댓글 0

단축키

Prev이전 문서

Next다음 문서

수정 삭제

단축키

Prev이전 문서

Next다음 문서

수정 삭제
Extra Form

MySQL Memory

MySQL은 하나의 프로세스로 동작 합니다. 세션은 thread로 확장되고 시스템 자원을 할당 받습니다.

MySQL의 Memory 부분은Connection 수의 영향을 받는 부분이며 항상 주의를 요해야 합니다.

 

● Memory Management

MySQL 레퍼런스에 나온 식 :

innodb_buffer_pool_size + key_buffer_size + max_connections*(sort_buffer_size+read_buffer_size+binlog_cache_size)

 

레퍼런스에 달린 코멘트 (by David Tonhofer)

total memory = 
    innodb_buffer_pool_size + 
    key_buffer_size +
    innodb_additional_mem_pool_size +
    innodb_log_buffer_size +
    max_connections * (sort_buffer_size + read_buffer_size + binlog_cache_size + thread_stack)

 

 

 항목 (64 Bit 기준)

Default

Range

Scope

Dynamic

innodb_buffer_pool_size

134217728

10전체 메모리의 70~80%가 적당합니다. G -> 12G , 32G -> 26G 정도를 설정 합니다.

Global

No

key_buffer_size

8388608

8-4294967295

Global

Yes

max_connections

151

1-100000

Global

Yes

sort_buffer_size

2097144

18446744073709547520

Global, Session

Yes

read_buffer_size

131072

8200-2147479552

Global, Session

Yes

binlog_cache_size

32768

4096-18446744073709547520

Global

Yes

innodb_additional_mem_pool_size

8388608

2097152-4294967295

Global

No

innodb_log_buffer_size

8388608

262144-4294967295

Global

No

thread_stack

262144

131072-18446744073709547520

Global

No

 

 

innodb_buffer_pool_size

:  InnoDB 가 data 와 index 를 캐싱하기 위해 사용하는 공간 입니다. default 값은 128M 입니다. 이 공간을 크게 잡을수록 디스크로의 I/O 는 감소됩니다. 데이터베이스용 서버라면 이 공간을 Physical Memory Size 의 80% 까지 잡기도 합니다.

 

다음 상황에 대해 크기를 줄이는 것을 고려해야 합니다.

1)Physical Memory 부족으로 OS 상에서 Paging 이 발생할 때

2)InnoDB 는 buffer 와 control structures 를 위해 일부 공간을 남겨둡니다. 그렇기 때문에 정의된 크기보다 10% 정도의 공간이 추가적으로 필요로 합니다.

3)buffer pool 을 초기화하는 시간은 이 파라미터의 크기에 비례 합니다. 이를테면 10GB 의 경우 6초 정도가 소요 됩니다.

 

key_buffer_size

: MyISAM 이 Index 를 캐싱하는데 사용하는 영역으로 key cache 로도 알려져 있습니다. 통상 Physical Memory 의 25% 정도는 허용범주로 볼 수 있지만 이 영역을 지나치게 크게 잡는 경우는 페이징이 발생하고 시스템이 매우 느려질 수 있습니다. 데이터 영역의 캐싱은 OS 의 SYSTEM CACHING 을 이용하기 때문입니다. 또한 다른 Storage Engine 이 사용할 영역도 고려해야 합니다.

 

max_connections

: mysql 에 접속할 있는 세션수를 의미 합니다. 해당 파라미터의 값을 변경해야 할 때는 시스템의 메모리 사용량을 고려해야 합니다.

 

sort_buffer_size

: 해당 Variable 은 특정 Storage 에 정의된 값이 아니어서 일반적으로 사용 가능합니다. (MyISAM, InnoDB 든 똑같은 영향을 받습니다.) 

특징으로는 이 sort 공간을 사용하는 경우 일량에 상관없이 전체 공간을 할당받아 사용한다는 것 입니다. 그렇기 때문에 특정 쿼리를 위해 global 하게 변경하는 것은 시스템 성능의 저해를 초래할 수 있으며 굳이 변경을 한다면 scope 를 session 으로 특정짓고 진행하는 것이 바람직 합니다.

 

read_buffer_size

: 각각의 시퀀셜 스캔을 수행하는 쓰레드는 스캔하는 테이블에 대해 설정된 크기(bytes) 만큼의 버퍼를 할당 받습니다. 해당 값은 4KB 의 배수값으로 설정되어야 하며 다른 값이 설정된 경우 내림으로 배수셋팅이 됩니다.

 

binlog_cache_size

: 트랜잭션 중 바이너리 로그에 대해 발생한 변경사항을 보유하기 위한 캐시 사이즈를 할당 합니다. 이 캐시는 서버가 트랜잭션을 지원하는 스토리지 서버를 사용하고 ( ex : InnoDB ) binary log 를 enable 한 상태라면 각 Client 에 대해 할당 됩니다.

 

innodb_log_buffer_size

: InnoDB 가 log files 를 disk 에 쓰기위한 buffer size 입니다. default 는 8M 이다. 큰 크기의 log buffer 는 large transactions 이 commit 되기 전에 log 를 disk 로 내려쓰는 것을 피할 수 있습니다.

 

thread_stack

: 각 쓰레드에 대한 스택사이즈를 정의 합니다. default 값은 256KB (64-bit system) 이며 통상적인 경우 충분 합니다. 만약 thread stack size 가 지나치게 작으면 그것은 서버가 핸들할 수 있는 복잡한 SQL 구문의 사용에 제약을 가하게 됩니다. (stored procedures 의 recursion depth, 기타 memory-consuming actions 들도 영향 받습니다. )

 

● 튜닝

 

1) MySQL이 사용 가능한 최대 메모리를 계산 합니다.

2) 정렬 버퍼나 임시테이블 등의 개별적인 연결에 필요한 메모리 양을 계산 합니다.

3) 운영체제가 필요한 메모리양을 계산 합니다. ( 주기적인 배치 작업 및 다른 프로그램이 실행되는데 필요한 메모리 양 고려)

4) 나머지 메모리를 InnoDB 버퍼 풀과 같은 MySQL 캐시로 사용 합니다.

 

참고 사항

: MyISAM 을 사용하지 않는다면 innodb_additional_mem_pool_size은 기본값인 8M으로 충분 합니다.

 InnoDB를 사용하지 않는다면 buffer size 를 OS 가 data 캐싱할 것을 고려하여 정해야 합니다. 이 경우 최초 MySQL 이 사용할 최대 메모리를 70 % 로 잡았지만 더 낮춰야 할 수 있습니다.

 

 

● Connection Memory 사용량 조회

 

SHOW VARIABLES LIKE 'innodb_buffer_pool_size';
SHOW VARIABLES LIKE 'innodb_additional_mem_pool_size';
SHOW VARIABLES LIKE 'innodb_log_buffer_size';
SHOW VARIABLES LIKE 'thread_stack';

 

● Connection 별 메모리 사용률 확인

 

SET @kilo_bytes = 1024;
SET @mega_bytes = @kilo_bytes * 1024;
SET @giga_bytes = @mega_bytes * 1024;
SET @innodb_buffer_pool_size = 2 * @giga_bytes;
SET @innodb_additional_mem_pool_size = 16 * @mega_bytes;
SET @innodb_log_buffer_size = 8 * @mega_bytes;
SET @thread_stack = 192 * @kilo_bytes;

SELECT
 ( @@key_buffer_size + @@query_cache_size + @@tmp_table_size
 + @innodb_buffer_pool_size + @innodb_additional_mem_pool_size
 + @innodb_log_buffer_size
 + @@max_connections * (
 @@read_buffer_size + @@read_rnd_buffer_size + @@sort_buffer_size
 + @@join_buffer_size + @@binlog_cache_size + @thread_stack
 ) ) / @giga_bytes AS MAX_MEMORY_GB;

 

 

실제메모리사용량   (Actual Used Physical Memory) Mem: total -(free + buffers + cached) buffers/cache: used
실제메모리 사용률  ( total - free - buffers - cached) / total (total - buffer/cashe: free) /total

 


컴퓨터/노트북/인터넷

IT 컴퓨터 기기를 좋아하는 사람들의 모임방

List of Articles
번호 분류 제목 조회 수 날짜
공지 뉴스 구글 최신 뉴스 file 1386 2024.12.12
HOT글 일반 아 진짜 요새 SKT 해킹 뭐시기 때문에 신경 쓰여 죽겠어 ㅠㅠ 2 237 2025.05.20
공지 사랑LOVE 포인트 만렙! 도전 4681 2025.03.19
공지 🚨(뉴비필독) 전체공지 & 포인트안내 3 25853 2024.11.04
공지 URL만 붙여넣으면 끝! 임베드 기능 20432 2025.01.21
10640 PHP에 다중 코어를 사용하는 방법 1 1409 2023.03.30
10639 CPU 코어 수보다 더 많은 PHP-FPM 자식을 실행하는 것이 맞습니까? 2 1441 2023.03.30
10638 유튜브 8k를 틀면 왜 버벅대는 건가요? 1 1349 2023.04.03
10637 혹시 중고 그래픽카드 as는 어떻게 얘기하구 받아야하나요?? 2 1949 2023.04.03
10636 다운로드 속도가 옳게 나오고 있는건가요? 1 1937 2023.04.03
10635 LG그램 노트북이 느려요. nvme ssd 캐시값에도 영향이 있나요? 1 3148 2023.05.01
10634 3440X1440 해상도 그래픽카드 추천부탁드립니다 2 3244 2023.05.01
10633 Nvme 아무데나 꽂아도 됨? 1 file 362 2023.05.05
10632 설계용 노트북 추천 1 372 2023.05.05
10631 휴대폰 기종 뭔지 아시는 선생님 계실까요 1 file 389 2023.05.05
10630 아ㅋㅋ 하드디스크 이거 망한 거지? file 388 2023.05.05
10629 HDD 8TB 할인 존버성공!! 2 375 2023.05.05
10628 알뜰로 가게 좀 도와조... 2 354 2023.05.05
10627 빅스떄노릴만한노트북추천해주세용 1 392 2023.05.05
10626 RX6600에서 3060Ti으로 1 352 2023.05.05
10625 5800x3d는 더이상 가격 안내려가겠지? 1 408 2023.05.05
10624 키보드 25만원이하로 사려는데 다 비슷하나요? 382 2023.05.05
10623 제 씨퓨 내장그래픽 안되는 제품인가요? 1 file 349 2023.05.05
10622 혹시 컴퓨터 의자 관심있으시거나 잘 아시는분 계실까요? 2 360 2023.05.05
10621 l3 캐쉬 메모리가 차이 나면 어떤게 체감이 오는건가요? 2 file 648 2023.05.22
10620 L3 캐쉬 유무 성능차이 1 863 2023.05.22
10619 기가바이트 Z790 어로스 익스트림 X, 디스플레이 내장 file 479 2023.06.02
10618 TSMC N3, SRAM 확장이 많이 어려워짐 file 461 2023.06.02
10617 젠슨황: 인텔 파운드리로 테스트 칩 생산함. 잘 작동 346 2023.06.02
10616 AMD, 라이젠 AI의 추론 처리를 시연 772 2023.06.02
10615 SK하이닉스 10나노급 5세대 DDR5, 세계 최초로 데이터센터 호환성 검증 돌입 716 2023.06.02
10614 중국 무어 스레드, 3584 코어와 7GB GDDR6 메모리의 MTT S70 GPU file 599 2023.06.02
10613 인텔 메테오레이크로 추측되는 CPU가 탑재된 MSI 노트북 file 437 2023.06.02
10612 ASUS, 360mm 일체형 수냉 쿨러와 리퀴드 메탈을 쓴 ROG 매트릭스 지포스 RTX 4090 file 814 2023.06.02
10611 엘더레이크 vs 랩터레이크 vs 사파이어래피즈 간의 다이 샷 비교 file 666 2023.06.02
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 355 Next
/ 355