웹마스터 팁

http://coffeenix.net/글쓴이 : 좋은진호(truefeel, http://coffeenix.net/ )
작성일 : 2003.9.2(화)
수정일 : 2003.9.7(일)

mytop은 MySQL DB 퍼포먼스를 top명령어처럼 실시간으로 모니터링하는 툴이다.
홈페이지 : http://jeremy.zawodny.com/mysql/mytop/

MySQL의 show full processlist와 show status 쿼리 결과값을 토대로 디스플레이하는데,
화면 설명은 뒤에서 할 것이다.

운영 환경은 다음과 같다. (mytop은 perl로 개발되었다.)

* Perl
* 펄 모듈 - DB관련 - DBI, DBD::mysql (필수)
* 펄 모듈 - Term::ReadKey  (필수)
* 펄 모듈 - 컬러로 보기위해서는 Term::ANSIColor (선택)
* 펄 모듈 - 보다 나은 실시간 정보를 위해서는 Time::HiRes (선택)

1) 설치

설치는 과정은 다음 순서대로.

펄 모듈 DBI, DBD::mysql -> Term::ReadKey ->선택사항과 관련된 모듈 -> mytop
DBI와 DBD::mysql 모듈은 보통 설치된 경우(Redhat 8이상은 기본, 7.x는 DBI 기본)가
많으며 설치 안됐더라고 CPAN에서 받아서 설치하면 된다.

http://search.cpan.org/dist/DBI/
http://search.cpan.org/dist/DBD-mysql/
http://search.cpan.org/dist/TermReadKey/
http://search.cpan.org/dist/ANSIColor/

모듈의 설치과정은 모두 다음 과정을 따르면 된다. mytop도 마찬가지 방법으로 설치한다.
-------------------------------------------
# tar xvfz ?????.tar.gz
# cd ?????
# perl Makefile.PL
# make
# make test
# make install
-------------------------------------------

2) 실행화면

# mytop -u root -p ?????? (???는 mysql DB root PW)



부분별 의미를 알아보자.

============================= ========================== =======================
표  시            의  미          관련 show status 변수명
============================== ========================== =======================
MySQL on localhost (3.23.49a)  호스트명과 MySQL 버전
------------------------------ -------------------------- -----------------------
up 11+23:04:23 [17:17:46]    MySQL uptime과 현재 시간  Uptime
============================== ========================== =======================
Queries: 947.4k         uptime중의 총 쿼리 개수   Questions
qps:  1 Slow:   0.0     초당 쿼리 수 평균과     Questions
                slow 쿼리 수        Slow_queries

※ Slow_queries이란 MySQL 서버 설정값인 long_query_time(default는 10초)보다 더 긴
  시간동안 질의된 쿼리 수를 의미한다.
------------------------------ -------------------------- -----------------------
Se/In/Up/De(%):  70/21/04/00 총 쿼리 중 각각 Select,   Com_select
                Insert+Replace,       Com_insert, Com_replace
                Update,           Com_update
                Delete 비율         Com_delete
============================== ========================== =======================
qps now:  2 Slow qps: 0.0   현재 쿼리 수와       Questions
                현재 slow 쿼리 수      Slow_queries
※ Slow qps가 자주 나오면 SQL문 최적화가 필요
------------------------------ -------------------------- -----------------------
Threads:  11 (  3/  0)    11은 쓰레드 총 개수     Threads_connected
                3은 동작중인 쓰레드     Threads_running
                0은 캐시된 쓰레드      Threads_cached
------------------------------ -------------------------- -----------------------
62/12/00/00           각각 현재의 Select,.. 비율 Com_select, ...
============================== ========================== =======================
Key Efficiency: 100.0%     Key 캐시 히트율       Key_reads, Key_read_requests

※ Key Efficiency 높을 수록 키 버퍼에서 읽어들인 것임.
  수치가 99%보다 낮다면 key_buffer_size 조정 필요
------------------------------ -------------------------- -----------------------
Bps in/out: 77.0/537.7     초당 주고받은 평균 bytes  Bytes_received
                              Bytes_send
------------------------------ -------------------------- -----------------------
Now in/out:  8.4/569.6     현재 주고받은 bytes     Bytes_received
                              Bytes_send
============================== ========================== =======================


다양한 실행 옵셥은 man페이지를 통해 확인하기 바란다.
또한 실행중 사용하는 키는 ? 를 누르면 도움말을 볼 수 있다.
c(command별 사용 비율과 건수), p(일시 정지), s(화면 업데이트간격 변경),
q(종료), i(sleeping 상태의 쓰레드 표시 여부 변경) 등 다양하다.

c를 눌러 command별(select, insert, update 등) 사용 비율과 건수를 보자.



3) ~/.mytop 환경 설정

mytop -u ??? -p ??? 처럼 실행했을 땐 패스워드 유출 가능성도 있고 매번 실행하기도
불편할 수 있다. 이럴 땐 홈디렉토리의 ~/.mytop에 설정해두면 된다.

-------------------------------------------
user=root
pass=???????
host=localhost
db=test
port=3306
socket=
-------------------------------------------

참고로 MySQL튜닝에 대한 글은 다음을 읽어보기 바란다.

응용프로그램에서의 최적화 DB와 Mysql (글 문태준)
http://coffeenix.net/doc/mysql/mysql_tuning.html

mysql 최적화 (번역 최영봉)
http://database.sarang.net/database/mysql/tuning/optimize_mysql.html
제목 글쓴이 날짜
운영하던 사이트의 도메인 주소를 변경했을때 기존 사이트의 이미지들이 엑박이 뜰때 해결방법 [4] 졸라맨 2012.03.05
클립보드로 텍스트 복사하기 [5] file 베니 2007.11.24
Google Analytics Addon 자료 최신 XE 에서 작동시키는 방법 [4] sejin7940 2012.10.05
크롭에 웹폰트 적용하기 css 꿈틀잉 2012.10.07
Admin 페이지에서 사이트맵 삭제가 안될 때 file FontBox 2012.10.06
회원설정에 레이아웃 설정이 생겼습니다. 회원정보보기페이지 레이아웃 설정 가능 [2] 똑디 2012.10.04
youtube, vimeo 자동 썸네일 생성 팁 1.5 이상 [3] 꿈틀잉 2012.09.19
iframe 아이프레임 투명처리 꿈틀잉 2012.10.04
실시간 쪽지 [10] file CMD 2012.09.20
제목 부분에 특수키 입력 못하게 막는 방법 [22] sejin7940 2012.09.21
[초보팁] 게시판 하단 버튼 정리 [2] 브레인630 2012.09.24
UTF-8에서 호환되는 사랑비 BGM 올립니다. [8] file 로로아 2008.10.15
XE스팸필터 등록 오류(1.5.3.2 적용후) [10] 정박사닷컴 2012.09.11
관리자의 회원정보 수정 페이지에 '가입일/최근접속일' 추가하기 [6] file showjean 2012.09.17
iframe을 이용한 악성코드 침투 - 치료 및 대응법 (검블러 or GENO) [8] file 미루819 2009.10.01
친절한설명! 자신의홈페이지에 간단히 음악넣기 [10] file 준봉쿠 2011.12.18
인증메일 때문에 고생하시는 분 참고하세요. [17] 박용식 2010.10.14
1.4 에서 1.5로 게시판 마이그레이션 팁 [12] file 마음의빈자리 2012.07.10
DB네임(테이블 프리픽스) 변경 방법 phpmyadmin 꿈틀잉 2012.09.12
startssl 에 가입하고 패널 들어갈때 인증서 못받으신분들 file 우리아기 2012.09.12