PHP PDO 연결이 안 됩니다.
안녕하세요.계속 삽질하다가 모르겠어서 질문 올려 봅니다.
VMPlayer + CentOS 5.8 + AMP + PDO 를 사용중입니다. ( PHP 5.3 )
실서버 리눅스 서비스 적용 전에 테스트 해 보려고 설치한 거고요. 실서버 소스도 PHP + PDO 로 만들어져 있습니다.
VMPlayer 에 Centos 를 설치 -> mysql 설치 -> apache 설치 -> php53 설치 -> pp53-pdo 를 설치했습니다( yum 이용 설치. 소스 컴파일 설치 아님 ).
아파치는 잘 돌아갑니다. localhost 접속해도 나오고, 127.0.0.1 접속해도 나오고요.
php 코드도 잘 돌아갑니다. phpinfo() 도 나옵니다.
그런데, PDO 가 잘 안되네요. OTL
아래와 같은 코드를 작성했습니다.
<?php
$pa = new PDO('mysql:host=127.0.0.1;dbname=test1", 'mysql아이디 ', 'mysql암호' );
var_dump($pa);
?>
실행하면 에러나는데, try-catch 로 PDO Error 찍어보면
"SQLSTATE[HY000][2003]Can't connect to MySQL server on '127.0.0.1'(13) "
이라고 나옵니다. 왜그럴까요?
1. 콘솔에서 #mysql -umysql아이디 -pmysql암호 -h127.0.0.1 하면 접속 잘 됩니다. ( Grent 로 user.host 값에 '%', 'localhost', '127.0.0.1' 모두 추가했습니다. )
2. 패키지 설치 후에, mysqld, httpd 를 모두 restart 해 줬습니다. 그래도 효과 없습니다.
3. 어디 뒤져보니까 mysql의 /etc/my.cnf 에 "bind-address = 127.0.0.1" 추가하면 잘된다는데, 저는 효과 없습니다.
4. php.ini 에
extension=pdo.so
extension=pdo_mysql.so
extension=mysql.so
추가해 봤습니다만, 효과 없습니다.
그리고 이상한 게 두 가지 더 있는데,
11. PDO 의 connection string 에서 host 값을 "host=127.0.0.1" 이 아니라 "host=localhost" 로 하면, 문제없이 잘 됩니다.
StackOverflow 에도 비슷한 증상을 써 놓은 사람들이 있는데, 리플로 딱히 해결책이 달리지는 않았더군요.
12. phpinfo() 를 보면, configure 옵션에 pdo 관련 값이 --disable-pdo 로 되어 있습니다.
근데 php 관련 값들은 enable 로 되어 있더군요.
phpinfo 에서 pdo 관련 값은 다음과 같습니다.
PDO
PDO support enabled
PDO drivers mysql, sqlite
pdo_mysql
PDO Driver for MySQL enabled
Client API version 5.0.95
이상입니다. 혹시 의견 있으신 분들은 덧글 부탁드립니다.
이상입니다. 좋은 하루 되시기 바랍니다.
cat /etc/hosts netstat -tlnp
cat /etc/hosts
netstat -tlnp | grep 3306
--
http://www.dgkim.net/
dgkim 님. 답글 감사드립니다.
3306 포트도 정상 작동중입니다. 하지만 안되더군요.
인터넷 뒤져보니까 전부 port forwarding 이야기 밖에 없어서, 일단 접었습니다.
dgkim님 답글 감사드립니다.
댓글 달기