> 데이터 베이스 > MySQL 튜토리얼 > 소켓을 통해 로컬 MySQL 서버에 연결할 수 없는 이유는 무엇입니까?

소켓을 통해 로컬 MySQL 서버에 연결할 수 없는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-10 20:33:17
원래의
1102명이 탐색했습니다.

Why Can't I Connect to My Local MySQL Server Through the Socket?

연결 문제 공개: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿