연결 문제 공개: MySQL 소켓 연결 이해
PHP의 mysqli 클래스를 사용하여 MySQL 데이터베이스 연결을 설정하려고 하면 다음과 같은 문제가 발생할 수 있습니다. 오류: "['MySQL' 소켓(2)을 통해 로컬 MySQL 서버에 연결할 수 없습니다.]". 이 오류는 MySQL 클라이언트가 TCP/IP 연결 대신 "localhost"의 Unix 도메인 소켓을 통해 연결을 시도할 때 발생합니다.
Unix 소켓과 TCP/IP 연결
기본적으로 Unix 시스템의 MySQL 프로그램은 "localhost"에 연결할 때 TCP/IP 연결보다 Unix 도메인 소켓을 선호합니다. 그러나 소켓을 사용할 수 없거나 특별히 TCP/IP 연결이 필요한 경우에는 다른 방법을 사용해야 합니다.
문제 해결
이 문제는 여러 솔루션으로 해결할 수 있습니다. 문제:
1. 명시적 TCP/IP 연결:
연결 문자열에 "localhost" 대신 IP 주소 "127.0.0.1" 또는 로컬 서버의 호스트 이름을 사용하세요. 이렇게 하면 클라이언트가 TCP/IP 연결을 설정하게 됩니다.
2. PHP 구성 수정:
MySQL 구성 파일(my.cnf)을 찾고 MySQL이 소켓을 설정하는 경로를 찾습니다. php.ini에서 PHP의 mysqli.default_socket을 이 경로로 설정합니다.
3. 명시적 소켓 구성:
PHP 스크립트에서 연결을 열 때 소켓 경로를 직접 지정하세요.
$db = new MySQLi('localhost', 'kamil', '***', '', 0, '/var/run/mysqld/mysqld.sock');
결론
By MySQL에서 사용하는 연결 메커니즘을 이해하면 이 오류를 극복하고 성공적인 데이터베이스 연결을 설정할 수 있습니다. Unix 도메인 소켓을 사용하면 성능과 보안상의 이점을 얻을 수 있지만 특정 경우에는 명시적인 TCP/IP 연결이 필요할 수 있습니다.
위 내용은 소켓을 통해 로컬 MySQL 서버에 연결할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!