skip-name-
resolve는 client 에서 server로 접속시에 DNS Lookup 과정을 생략해 줍니다. localhost 로 접속하는
경우는 문제가 없지만 IP 로 접속하는 환경에서는 DNS 서버가 느리거나 아님 장애 발생시에 해당 옵션을 설정해 주므로써 DB
접속시에 문제점을 해결하실 수 있습니다.
[root@smson root]# vi /etc/my.cnf
# The MySQL server
[mysqld]
skip-external-locking
skip-host-cache
skip-locking
skip-name-resolve
back_log = 768
basedir = /opt/mysql/
connect_timeout = 30
아래와 같이 show processlist 명령을 수행해서 unauthenticated user 가 표시되면
DB 연결 속도가 떨어지고, 웹페이지 접속이 느려진다.
mysql> show processlist;
| 3436942 | unauthenticated user | 192.168.0.52:49607 || Connect|| login |
| 3436943 | unauthenticated user | 192.168.0.52:49608 || Connect|| login
1. 해결방법
mysql 시작시 --skip-name-resolve 옵션을 줘서 실행한다.
또는 /etc/hosts 파일에 접속 IP와 호스트명을 넣어준다.
2. 원인?
mysql에서 접속시 ip에 대한 resolving(역질의)를 한다. 하지만, 대부분의 IP는 등록되어 있지 않으며,
DNS가 느리다면 이 부분은 더욱 심각한 속도 문제가 발생한다. mysql 4.0.XX에서는 보이자
않았던 문젠데... 4.1.X 부터는 문제가 보이기 시작했다. 위 해결법들은.
역질의를 하지 않는 방법과, DNS가 아닌 /etc/hosts파일에서 질의 하게 하는 방법이다.
둘 중 빠른 방법은 역질의하지 않게 하는것이며, DB를 잠시라도 정지하기 힘든 시스템에서는
두번째 방법을 사용하여 한가할 때 전자의 방법으로 바꾸는 것이 좋을 것으로 판단된다.
[MYSQL 접속함]
[root@DWSM logs]# mysql --user=root -p.digital
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 1 to server version: 4.1.11-log
mysql> use mysql;
Database changed
mysql> select * from user where User ='ering'; <<- 사용자 확인한다.
+-----------+-------+-------------------------------------------+-------------+----------
|
Host | User | Password |
Select_priv | Insert_priv | Update_priv | Delete_priv | Create_priv |
Drop_priv | Reload_pr
iv |
Shutdown_priv | Process_priv | File_priv | Grant_priv | References_priv |
Index_priv | Alter_priv | Show_db_priv | Super_priv |
Create_tmp_table_priv |
Lock_tables_priv
| Execute_priv | Repl_slave_priv | Repl_client_priv | ssl_type |
ssl_cipher | x509_issuer | x509_subject | max_questions | max_updates |
max
_connections |
+-----------+-------+-------------------------------------------+-------------+----------
| localhost
| ering | *A3279FE22E79F49A496CBFB6A9E9D30CD68E4052 | Y |
Y | Y | Y | Y | Y | Y
| Y | Y | Y | Y |
N | N | N | N | N |
N |
N
| N | N | N |
| | | | 0 | 0 |
0 |
1 row in set (0.00 sec)
mysql> INSERT INTO user VALUES ('%','ering', password('.digital'),'Y','Y','Y','Y','Y','Y',
-> 'Y','Y','Y','Y','Y','N','N','N','N','N','N','N','N','N','N','','','','',0,0,0);
Query OK, 1 row affected (0.00 sec)
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
mysql> quit
Bye
[root@DWSM logs]# /etc/init.d/mysql restart
Shutting down MySQL. SUCCESS!
Starting MySQL SUCCESS!
제목 | 날짜 | ||
---|---|---|---|
18 | [웹로그] 파이어폭스 추천 확장기능 | 9469 | 2007/11/12 |
17 | [웹로그] MySQL 관련 팁 | 9515 | 2010/09/19 |
16 | [웹로그] mysql의 최대 성능 향상 방법 | 9612 | 2010/09/19 |
15 | [웹로그] 아이튠즈를 업데이트 후 실행이 안될 때 [1] | 9716 | 2007/11/21 |
14 | [웹로그] 홈페이지 속도 개선 | 9745 | 2010/09/19 |
13 | [웹로그] 입력폼과 이미지폼의 정렬은 어떻게 맞추나요? | 9776 | 2007/11/09 |
[웹로그] [DB 속도저하에 따른 웹페이지 접속 지연] skip-name-resolve 옵션 [2] | 9942 | 2010/09/19 | |
11 | [웹로그] mysql index 속도 높이기 | 10299 | 2010/09/19 |
10 | [웹로그] 해당 디렉토리의 하위 디렉토리별 용량 알아보기 | 11016 | 2010/08/17 |
9 | [웹로그] BlogAPI를 이용해서 제로보드XE에 글 올리기 | 11275 | 2007/11/18 |
8 | [웹로그] 알약 설치 후 - AYServiceNT.aye 라는 서비스는 왜 자동 시작되는 걸까? [3] [2] | 11378 | 2007/11/12 |
7 | [웹로그] MySQL euc-kr, latin1 문자코드 UTF-8로 컨버팅 하기 [1] | 11559 | 2010/09/17 |