来源:自学PHP网 时间:2015-04-16 10:51 作者: 阅读:次
[导读] 1 1 1 mysql本机登录mysql时,-S参数失效【环境描述】mysql5 5 14【问题描述】配置了多实例 实例1实例2datadir home mysql_3306 home mysql_3307basedir usr usrs...
1.1.1. mysql本机登录mysql时,-S参数失效 【环境描述】 mysql5.5.14 【问题描述】 配置了多实例
登录实例2的时候,却连接到了实例1: mysql -S /home/mysql_3307/mysql.sock > show variables like '%sock%'; +---------------+-----------------------------+ | Variable_name | Value | +---------------+-----------------------------+ | socket | /home/mysql_3306/mysql.sock | +---------------+-----------------------------+ 【问题原因】 mysql命令中的-S参数是用来指定unix_socket,但是此时mysql很明显没有使用socket。 查看/etc/my.cnf配置文件,发现[client]域配置如下: [client] host = 127.0.0.1 尝试修改host=localhost 和注释掉host,再次尝试登录mysql: mysql -S /home/mysql_3307/mysql.sock > show variables like '%sock%'; +---------------+-----------------------------+ | Variable_name | Value | +---------------+-----------------------------+ | socket | /home/mysql_3307/mysql.sock | +---------------+-----------------------------+ 此时,正常登录上了指定的实例。 再次测试登录mysql: mysql -S /home/mysql_3306/mysql.sock -h 127.0.0.1-P 3307 > show variables like '%sock%'; +---------------+-----------------------------+ | Variable_name | Value | +---------------+-----------------------------+ | socket | /home/mysql_3307/mysql.sock | +---------------+-----------------------------+ mysql登录的时候指定的socket是3306端口的,host是127.0.0.1,port是3307,登录后,连接的是3307端口的实例, mysql -S /home/mysql_3307/mysql.sock -h127.0.0.1 > show variables like '%sock%'; +---------------+-----------------------------+ | Variable_name | Value | +---------------+-----------------------------+ | socket | /home/mysql_3306/mysql.sock | +---------------+-----------------------------+ mysql登录的时候指定的socket是3307端口的,host是127.0.0.1,port没有指定,登录后,连接的是3306端口的实例。 综上,mysql客户端连接mysql数据库的时候,如果同时指定了socket和host的时候,mysql会采用TCP/IP协议登录,此时socket会被忽略,默认情况下访问3306端口。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com