网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

centos安装LAMP环境时访问本地MYSQL数据库错误-创新互联

近日在安装LAMP环境时访问本地MYSQL数据库错误

成都创新互联公司-专业网站定制、快速模板网站建设、高性价比温江网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式温江网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖温江地区。费用合理售后完善,10余年实体公司更值得信赖。

错误如下:

Warning: mysqli::mysqli(): (HY000/2002): Can't connect to local MySQL server

问题描述:

由于将安装mysql服务器文件位置修改在home目录下,造成本地访问问题。

在网上找了很久终于找到解决问题的方法:

1、先确保在本机上使用命令能登陆,如果也出现提示sock文件位置问题,那么需要修改mysql配置文件(/etc/my.cnf)

增加如下配置:

[mysql]

socket=/home/mysqldata/mysql.sock#这是我的sock文件的位置

2、php使用mysqli无法访问问题

解决方法:

找到PHP配置文件(/etc/php.ini)找到mysqli.default_socket这个值

修改为mysqli.default_socket =/home/mysqldata/mysql.sock#这是我的sock文件的位置

问题分析(这是我在网上找到的解决方案):

On Unix, MySQL programs treat the host name localhost specially, in a way that is likely different from what you expect compared to other network-based programs. For connections to localhost, MySQL programs attempt to connect to the local server by using a Unix socket file. This occurs even if a --port or -P option is given to specify a port number. To ensure that the client makes a TCP/IP connection to the local server, use --host or -h to specify a host name value of 127.0.0.1, or the IP address or name of the local server. You can also specify the connection protocol explicitly, even for localhost, by using the --protocol=TCP option.

其实就是说UNIX系统需要将localhost 这个地址进行转换的文件

解决的方法其他有三个

There are a few ways to solve this problem.

  1. You can just use TCP/IP instead of the Unix socket. You would do this by using 127.0.0.1instead of localhost when you connect. The Unix socket might by faster and safer to use, though.

  2. You can change the socket in php.ini: open the MySQL configuration file my.cnf to find where MySQL creates the socket, and set PHP's mysqli.default_socket to that path. On my system it's /var/run/mysqld/mysqld.sock.

  3. Configure the socket directly in the PHP script when opening the connection. For example:

    $db = new MySQLi('localhost', 'kamil', '***', '', 0, 
                                  '/var/run/mysqld/mysqld.sock')

1、修改连接文件中localhost 为127.0.0.1

2、查看my.cnf文件中sock文件的位子,并赋值到php.ini:文件中的mysqli.default_socket去

3、PHP语言直接多一个参数指向sock文件位置。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


新闻名称:centos安装LAMP环境时访问本地MYSQL数据库错误-创新互联
本文URL:http://bjjierui.cn/article/psogo.html

其他资讯