RadarURL
Skip to content
2015.03.16 18:52

MySQL Query Cache 사용법

조회 수 418 추천 수 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
번호 제목 글쓴이 날짜 조회 수
39 mySQL에서 사용자와 권한 처누 2004.04.16 7326
38 Mysql 기초-DB 설치, 관리자지정, 계정추가 등 처누 2004.06.06 7355
37 MySql 테이블 검사 및 복구하기 [ myisamchk ] JaeSoo 2005.11.26 6892
36 mysql에서 사용자 계정 비밀번호 변경 방법 JaeSoo 2006.02.16 7859
35 MySQL에서 테이블을 생성할때 MyISAM과 InnoDB 어느것을 선택하나요? JaeSoo 2010.01.25 7581
34 [Mysql] 범위 삭제 DELETE 쿼리 JaeSoo 2010.05.05 8115
33 mysql 4.x 버전의 euc-kr(latin1) DB를 mysql 5.x 버전으로 이전 하는법 JaeSoo 2011.04.30 8529
32 MySQL Dump뜨는 방법 및 복구 방법 JaeSoo 2011.06.08 10702
31 fedora core4 mysql 서버설치 및 windows client로 접속 JaeSoo 2011.06.16 12686
30 [Fedora 8] Mysql 5.0.67 설치 JaeSoo 2011.06.16 10362
29 Mysql DB 손상됬을경우 점검 및 복구 명령 JaeSoo 2011.09.16 9270
28 MySQL 재설치시 오류 JaeSoo 2011.11.15 7600
27 MySQL Data file 위치 JaeSoo 2011.11.15 5561
26 MySQL Plugin 'InnoDB' init function returned error. JaeSoo 2011.11.15 5745
25 mysqlcheck 유틸리티 사용법(analyze, optimize, repair) JaeSoo 2012.06.05 4627
24 윈도우환경에서 MySQL 설치하기 JaeSoo 2013.03.13 3534
23 MySQL database 정보 import하기 JaeSoo 2013.03.13 1355
22 MySQL 테이블 형태 변경하기 MyISAM -> InnoDB(또는 InnoDB -> MyISAM) JaeSoo 2013.03.19 1617
21 [MySQL] phpMyAdmin으로 MyISAM 테이블 형식을 InnoDB로 바꾸기 JaeSoo 2013.03.19 6768
20 왜 MySQL 에서 InnoDB 를 써야하는가? InnoDB vs MyISAM 비교 JaeSoo 2013.04.12 3935
Board Pagination Prev 1 2 Next
/ 2

PageViews   Today : 4612 Yesterday : 5037 Total : 21960664  /  Counter Status   Today : 4474 Yesterday : 4602 Total : 1187197

Edited by JAESOO

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소