PHP PDO 연결이 안 됩니다.

cococo의 이미지

안녕하세요.계속 삽질하다가 모르겠어서 질문 올려 봅니다.

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

이상입니다. 혹시 의견 있으신 분들은 덧글 부탁드립니다.

이상입니다. 좋은 하루 되시기 바랍니다.

dgkim의 이미지

cat /etc/hosts

netstat -tlnp | grep 3306

--
http://www.dgkim.net/

cococo의 이미지

3306 포트도 정상 작동중입니다. 하지만 안되더군요.

인터넷 뒤져보니까 전부 port forwarding 이야기 밖에 없어서, 일단 접었습니다.

dgkim님 답글 감사드립니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.