2003-11-17
81 HIT
|
| Warning: Can't connect to local MySQL server through socket '/home/mysql/mysql.sock' (111) in /home/dspaper/public_html/board/index.html on line 15 [문제의 원인] 실제로 mysqld 에 의한 socket 파일은 /tmp/mysql.sock 에 존재하는데 PHP 나 mysql 과 같은 프로그램들은 그 파일을 /var/lib/mysql/mysql.sock 에서 찾는다. 그러니 당연히 mysqld 와 의사소통이 될리가 없고, 접속이 안된다고 에러가 납니다. [해결방법] 1. ln -sf /tmp/mysql.sock /var/lib/mysql/mysql.sock 이 해결법은 가장 간단하게 할 수 있지만 문제점은 리부팅 되고 나면 그때마다 다시 이 soft link 를 걸어 줘야 합니다. 왜냐하면 이 파일은 일반적인 파일이 아닌 unix socket 파일이기 때문입니다. 2. msyqld 기동시에 --socket=/var/lib/mysql/mysql.sock 라는 옵션을 추가 이 방법은 강제적으로 소켓 파일을 원하는 디렉토리에 만들도록 해 줍니다. 그러므로 mysqld 의 소켓파일이 저 디렉토리에 생성만 된다면 문제는 해결이 되겠지요. 3. PHP 연동시 client 측에서 socket 파일의 위치를 지정해 주는 방법 $conn = mysql_connect("localhost:/tmp/mysql.sock","db_user","db_passwd"); 이 방법은 클라이언트 측에서 서버측의 소켓파일의 위치를 명시해 주는 방법입니다. (얼마나 이런 문제가 많았으면 저런 방법까지 생겼을꼬....) 대부분의 경우 위 3가지 방법으로 다 해결이 됩니다. |

