Rumah > pembangunan bahagian belakang > tutorial php > Mengapa Skrip PHP Saya Tidak Boleh Bersambung ke Pelayan MySQL melalui Soket?

Mengapa Skrip PHP Saya Tidak Boleh Bersambung ke Pelayan MySQL melalui Soket?

Patricia Arquette
Lepaskan: 2024-12-08 21:05:18
asal
562 orang telah melayarinya

Why Can't My PHP Script Connect to the MySQL Server via Socket?

Ralat: Tidak Dapat Menyambung ke Pelayan MySQL melalui Soket

Masalah

Apabila cuba menyambung ke pangkalan data MySQL menggunakan kelas PHP MySQLi, ralat berikut berlaku:

mysqli::mysqli(): (HY000/2002): Can't connect to local MySQL server through socket 'MySQL' (2)
Salin selepas log masuk

Analisis

Mesej ralat mencadangkan bahawa pustaka klien MySQL cuba menyambung ke pelayan melalui soket domain Unix bernama "MySQL," tetapi soket itu tidak wujud atau tidak tersedia.

Menurut dokumentasi MySQL, pustaka klien merawat nama hos "localhost" khas pada sistem Unix. Secara lalai, ia cuba menyambung menggunakan fail soket Unix, walaupun nombor port ditentukan.

Penyelesaian

Untuk menyelesaikan ralat ini, pertimbangkan pilihan berikut:

1. Gunakan TCP/IP:

Gunakan 127.0.0.1 sebagai nama hos dan bukannya "localhost" semasa membuat sambungan. Ini akan memaksa perpustakaan menggunakan sambungan TCP/IP, yang lebih dipercayai dan mudah alih.

2. Tukar Soket dalam php.ini:

Cari fail konfigurasi MySQL (my.cnf) dan cari laluan di mana MySQL mencipta soket. Kemudian, tetapkan arahan mysqli.default_socket PHP kepada laluan itu dalam fail php.ini.

3. Konfigurasikan Soket dalam Skrip PHP:

Nyatakan soket terus dalam skrip PHP apabila membuka sambungan:

$db = new MySQLi('localhost', 'kamil', '***', '', 0, '/var/run/mysqld/mysqld.sock');
Salin selepas log masuk

Maklumat Tambahan

Jika menyambung dari alat kawalan jauh Alamat IP, pastikan anda telah mencipta pengguna dengan keistimewaan yang diperlukan untuk sambungan luaran dalam pangkalan data MySQL.

Atas ialah kandungan terperinci Mengapa Skrip PHP Saya Tidak Boleh Bersambung ke Pelayan MySQL melalui Soket?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan