Perfect solution to the problem that MySQL cannot connect to the database through localhost

Perfect solution to the problem that MySQL cannot connect to the database through localhost

Problem: The PHP program on one server cannot connect to the database via the localhost address, but can connect normally if it is set to 127.0.0.1, and can also connect to other database servers normally. The MySQL permissions are set correctly, and the database can be connected normally through the mysql command line client.

Analysis: This is a typical case where the socket is not configured correctly.

There are two ways to connect to a MySQL database: TCP/IP (the kind commonly understood as a port) and Unix sockets (generally called sockets or socks). In most cases, localhost can be used to represent the local machine 127.0.0.1, but when connecting to MySQL, the two cannot be mixed, and localhost and 127.0.0.1 are also set separately in the permission settings in MySQL. When set to 127.0.0.1, the system connects to the database via TCP/IP; when set to localhost, the system connects to the database via socket.

Solution: First, check where the socket file of the local MySQL is. The command to check is:

mysqld --verbose --help | grep socket

The output shows the location of the socket file. For example, this server shows

socket /var/run/mysqld/mysqld.sock

Then modify the php configuration file php.ini to correspond to it.

Find this one:

mysql.default_socket =

Generally this item is empty, change it to:

mysql.default_socket = /var/run/mysqld/mysqld.sock

The file queried in the previous step should be written here and set according to your situation. At this point, the PHP configuration has been modified. If it is CLI (command line) mode or CGI mode, it will take effect immediately. If it is FASTCGI mode, you need to restart the fastcgi process.

The above article perfectly solves the problem that MySQL cannot connect to the database through localhost. This is all the content that the editor shares with you. I hope it can give you a reference. I also hope that you will support 123WORDPRESS.COM.

You may also be interested in:
  • How to quickly modify the host attribute of a MySQL user
  • Does the % in the newly created MySQL user include localhost?
  • How to allow all hosts to access mysql
  • Solution to the problem that MySQL can connect using localhost but cannot connect using IP
  • A brief discussion on the matching rules of host and user when Mysql connects to the database

<<:  Graphical tutorial on installing CentOS 7.3 on VMWare

>>:  Implementation of vscode custom vue template

Recommend

Native js encapsulation seamless carousel function

Native js encapsulated seamless carousel plug-in,...

Steps to export the fields and related attributes of MySQL tables

Need to export the fields and properties of the t...

Detailed explanation of the use of shared memory in nginx

In the nginx process model, tasks such as traffic...

Detailed explanation of gcc command usage under Linux system

Table of contents 1. Preprocessing 2. Compilation...

JavaScript+html implements random QR code verification on front-end pages

Share the cool front-end page random QR code veri...

An example of how JavaScript can prevent duplicate network requests

Preface During development, we often encounter va...

Ubuntu16.04 installation mysql5.7.22 graphic tutorial

VMware12.0+Ubuntu16.04+MySQL5.7.22 installation t...

How to get the height of MySQL innodb B+tree

Preface The reason why MySQL's innodb engine ...

The big role of HTML meta

There are two meta attributes: name and http-equiv...

HTML Basics - Simple Example of Setting Hyperlink Style

*** Example of setting the style of a hyperlink a...

docker cp copy files and enter the container

Enter the running container # Enter the container...

HTTP Status Codes

This status code provides information about the s...

How to invert the implementation of a Bezier curve in CSS

First, let’s take a look at a CSS carousel animat...

CSS margin overlap and how to prevent it

The vertically adjacent edges of two or more bloc...

Summary of the understanding of virtual DOM in Vue

It is essentially a common js object used to desc...