웹 느릴 때 꼭 해보는 DB 쿼리 로그 팁 공유합니다
안녕하세요 개발자 여러분
요즘 그누보드든, 워드프레스든, 영카트든 사이트가 좀 느리다 싶을 때
무조건 CSS/JS 때문이라고 생각하는 경우가 있는데요,
사실 DB 쿼리 병목이 주범인 경우가 꽤 많더라구요.
그래서 오늘은 제가 실무에서 자주 쓰는 SQL 쿼리 로깅 팁 하나 공유드려요.
이거 한번 써보시면 어떤 쿼리가 많이 돌고 느린지 금방 알 수 있어서
속도 튜닝에 큰 도움이 됩니다.
방법 1: PHP 코드에서 직접 로그 찍기
// common.php 또는 config.php에 추가
function log_query($sql) {
$log_file = G5_DATA_PATH.'/query_log.txt';
file_put_contents($log_file, date('Y-m-d H:i:s').' | '.$sql."\n", FILE_APPEND);
return $sql;
}
// 쿼리 실행 시 이렇게 호출
$sql = "SELECT * FROM g5_write_board WHERE wr_id = 1";
sql_query(log_query($sql));
이렇게 하면 /data/query_log.txt 파일에 날짜랑 쿼리가 하나씩 기록됩니다.
나중에 파일 열어서 보면 같은 쿼리가 10번, 100번씩 돌고 있는 것도 쉽게 보입니다.
방법 2: MySQL 자체 기능으로 느린 쿼리 추적
-- MySQL 콘솔에서
SET GLOBAL slow_query_log = 'ON';
SET GLOBAL slow_query_log_file = '/var/log/mysql-slow.log';
SET GLOBAL long_query_time = 1; -- 1초 이상 걸리는 쿼리만 기록
서버 접근 권한 있으신 분들은 이 방법도 좋습니다.
mysql-slow.log 파일 열어보면 진짜 병목 쿼리들이 그대로 찍혀요.
댓글 1개
감사합니다 데이터 베이스 잘 다루시는 분들 보면 부럽더라구요 : )
게시판 목록
개발자팁
질문은 QA에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 4976 | 기타 | 5년 전 | 2120 | ||
| 4975 | 웹서버 |
nooree
|
5년 전 | 2768 | |
| 4974 | node.js |
younhoso
|
5년 전 | 2135 | |
| 4973 | PHP |
|
5년 전 | 3639 | |
| 4972 | 기타 |
younhoso
|
6년 전 | 2262 | |
| 4971 | JavaScript | 6년 전 | 2488 | ||
| 4970 | 웹서버 | 6년 전 | 4124 | ||
| 4969 | JavaScript |
|
6년 전 | 2783 | |
| 4968 | JavaScript |
|
6년 전 | 1935 | |
| 4967 | JavaScript |
younhoso
|
6년 전 | 2045 | |
| 4966 | JavaScript |
|
6년 전 | 2116 | |
| 4965 | PHP |
|
6년 전 | 2104 | |
| 4964 | 기타 | 6년 전 | 2922 | ||
| 4963 | JavaScript | 6년 전 | 2090 | ||
| 4962 | JavaScript | 6년 전 | 2286 | ||
| 4961 | jQuery |
아이티몬스
|
6년 전 | 2094 | |
| 4960 | PHP | 6년 전 | 2739 | ||
| 4959 | 기타 | 6년 전 | 2567 | ||
| 4958 | PHP |
아이티몬스
|
6년 전 | 4577 | |
| 4957 | 기타 | 6년 전 | 2096 | ||
| 4956 | 정규표현식 |
하늘위의길
|
6년 전 | 2324 | |
| 4955 | 정규표현식 |
하늘위의길
|
6년 전 | 2676 | |
| 4954 | 웹서버 |
하늘위의길
|
6년 전 | 4138 | |
| 4953 | PHP | 6년 전 | 2526 | ||
| 4952 | PHP |
몰라무서워
|
6년 전 | 3213 | |
| 4951 | MySQL | 6년 전 | 4131 | ||
| 4950 | jQuery | 6년 전 | 3614 | ||
| 4949 | node.js | 6년 전 | 2682 | ||
| 4948 | node.js | 6년 전 | 2406 | ||
| 4947 | node.js | 6년 전 | 2647 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기