RadarURL

데이터베이스
2015.03.16 18:48

MySQL Query Cache 사용법

조회 수 708 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

MySQL에서는 반복되는 쿼리를 효율적으로 처리하기 위한 캐쉬가 존재한다.

바로 query cache인데 이는 까다로운 조건에 의해 동작하고 pruning 과정에서 meta 정보의 lock이 발생할 수 있어서 조심해서 사용해야 한다.

일단 동작하는 조건은 아래와 같다.

query cache에는 SQL문과 result set이 저장된다. 바로 이 cache에 저장되어 있는 SQL 문과 완전 동일(띄어쓰기까지..)하고 result set이 같은 쿼리가 수행될 때 query cache가 동작하고 result set을 바로 반환한다.

보통 개발자들은 위와 같은 조건을 간과하고 무작정 같은 쿼리를 수행하면 query cache를 쓰는 것으로 알고 사용한다.

그렇게 아무렇게나 쓰면 waiting query cache lock이라는 상태를 가진 프로세스로 인해 MySQL 서버가 hang이 걸릴 것이다…(오랜시간 고쳐지지 않고 있는 버그..)

이러한 상태에 빠지는 것을 방지하기 위해서는 꼭 query cache를 사용해야 하는 쿼리에만 사용하도록 옵션을 주어 사용할 수 있다.

 

query cache는 query_cache_type이라는 옵션을 통해 세 가지 타입을 제공한다.

OFF (0) ? Query cache를 사용하지 않는다.

ON (1) ? Query cache를 사용한다. (SQL_NO_CACHE 힌트를 사용하는 쿼리는 query cache를 사용하지 않는다.)

DEMAND (2) ? 선택한 쿼리만 query cache를 사용한다. (SQL_CACHE 힌트를 사용하는 쿼리는 query cache를 사용한다.)

 

위와 같은 설정은 my.cnf에서 설정 가능하고 세션 상에서도 설정이 가능하다.

# 세션에서 dynamic하게 설정하는 방법

 mysql> set global query_cache_type = 1;

 

# my.cnf에 설정 (재시작 시 적용)

[mysqld]

query_cache_type = 1;

설정은 숫자로 설정을 하거나 alias를 통해 설정이 가능하다.

 

query cache를 OFF할 경우에도 query_cache_size만큼 메모리를 할당하므로 해당 설정값을 0으로 설정하는 것을 권고한다.

query cache를 사용할 경우에는 query_cache_size를 1024의 배수로 설정해야 한다. 다른 값으로 설정할 경우 반올림하여 적용된다.

구조상 최소한 40KB 이상으로 설정해야 하며 적은 값으로 설정할 경우 warning이 발생한다.

해당 값은 아래와 같이 설정한다.

# 세션에서 dynamic하게 설정하는 방법

mysql> set global query_cache_size = 16*1024*1024;

 

# my.cnf에 설정 (재시작 시 적용)

[mysqld]

query_cache_size = 16M;



출처 : http://www.soonpenge.com/operate/12507175

TAG •
?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 928121
24 데이터베이스 MySQL Dump / Import (덤프 / 임포트) JaeSoo 2016.10.10 230
23 데이터베이스 Mysql slow-query를 이용한 로그 분석 JaeSoo 2015.03.17 697
22 데이터베이스 Mysql 데몬 문제 해결 방안 (cpulimit) 2 JaeSoo 2015.03.17 911
21 데이터베이스 mysql 5.5.x my.cnf 참고 JaeSoo 2015.03.16 673
20 데이터베이스 Mysql Slow query log 등록 JaeSoo 2015.03.16 785
19 데이터베이스 MYSQL 성능 향상 정리 JaeSoo 2015.03.16 628
» 데이터베이스 MySQL Query Cache 사용법 JaeSoo 2015.03.16 708
17 데이터베이스 Mysql 에서 Got a packet bigger than 'max_allowed_packet' bytes 오류 JaeSoo 2014.12.25 925
16 데이터베이스 Mysql binary log 정리, 삭제 주기 설정 JaeSoo 2014.11.17 1158
15 데이터베이스 MySQL 로그 파일 관리 2 - 로그 파일 남기기 JaeSoo 2014.11.17 1238
14 데이터베이스 MySQL 로그 파일 관리 1 - 설정 JaeSoo 2014.11.17 1156
13 데이터베이스 MySQL Binary Log 지우는 방법 JaeSoo 2014.11.17 1222
12 데이터베이스 MySQL 설치/사용시 발생 에러 유형별 대처방법 JaeSoo 2014.11.17 6890
11 데이터베이스 Mysql 데이터 폴더의 mysql-bin.xxx 파일들 관련 삭제 및 초기화 방법 JaeSoo 2014.11.17 1115
10 데이터베이스 MySQL my.cnf 파일 수정으로 mysql 서버 튜닝하기 JaeSoo 2014.07.07 1797
9 데이터베이스 MySQL에 원격 접속 허용 JaeSoo 2014.07.07 1374
8 유닉스/리눅스 리눅스에서 MYSQL 데이터 디렉토리 변경 JaeSoo 2014.06.04 1905
7 웹 프로그래밍 PHP MySQL 명령어 실행 함수 mysql_query JaeSoo 2014.04.29 1670
6 데이터베이스 mysql에서 (테이블명) is marked as crashed and should be repaired 에러시 JaeSoo 2014.01.23 2304
5 데이터베이스 왜 MySQL 에서 InnoDB 를 써야하는가? InnoDB vs MyISAM 비교 file JaeSoo 2013.04.12 5116
Board Pagination Prev 1 2 Next
/ 2


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너