博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2002 - Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (13 "权限不够")
阅读量:4166 次
发布时间:2019-05-26

本文共 1483 字,大约阅读时间需要 4 分钟。

2002 - Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (13 “权限不够”)

本地mysql客户端 或 navicae客户端 或 python程序 连接mysql-server时报错。

本机是ubuntu 16.04系统 ,使用命令安装mysql:
sudo apt-get install mysql-server mysql-client
本机mysql客户端连接mysql没有问题: mysql mysql -u root -p
但是使用navicate连接mysql时出现此错误:
在这里插入图片描述
在这里插入图片描述
网上查了很多方法文章,这里总结一下。

情况一: 本地mysql客户端不能连接mysql

错误提醒 socket ‘/var/lib/mysql/mysql.sock’ 这个目录是连接本地mysql通常通过一个Unix域套接字文件进行的,即这个mysql.sock套接字文件配置有问题,本地客户端就不能连接。

ubuntu系统的mysql 配置文件在 /etc/mysql/my.cnf ,在此目录里还有一个mysql.cnf ,这两个文件是通过软连接的同一个文件, 我在my.cnf里添加配置信息,mysql.cnf 里会自动改变 。

使用mysql客户端不能连接到mysql服务端,是因为mysql连接的时候,使用了这个配置文件的 [client] 部分 , 新安装的mysql 配置文件里是没有内容的, 也就没有指定客户端的mysql.sock 套接字文件位置 ; 默认使用的是 mysql-server 服务端的配置 ,在

/etc /mysql /mysql.conf.d /mysqld.cnf 里;

[mysqld]pid-file        = /var/run/mysqld/mysqld.pidsocket          = /var/run/mysqld/mysqld.sockport            = 3306basedir         = /usrdatadir         = /var/lib/mysql

所以需要配置一下mysql客户端的mysql.sock 套接字文件, 在配置文件/etc/mysql/my.cnf 里添加 :

[client]port  = 3306socket  = /var/lib/mysql/mysql.sock

重启mysql , 让配置文件生效 : service mysql restart

如果发现会报错, 在把配置文件里的 socket = /var/lib/mysql/mysql.sock 去掉,再执行重启mysql , 一般都没有问题,在登陆mysql : mysql -u root -p


情况二 :mysql客户端可以连接,其他客户端不能连接

本机是mysql客户端可以连接mysql,登陆成功,但是navicate 客户端连接mysql失败,我找了很多解决方法,改配置文件,改来改去都没有解决,又看了mysql 服务端的配置 /etc /mysql /mysql.conf.d /mysqld.cnf

[mysqld]bind-address            = 127.0.0.1   // mysql服务监听地址

原来navicate的连接信息:

在这里插入图片描述
此时主机: localhost ,连接失败 .
把主机 改成 127.0.0.1
在这里插入图片描述
连接成功;

转载地址:http://unqxi.baihongyu.com/

你可能感兴趣的文章
NUMA架构下的CPU拓扑结构
查看>>
如何判断变量在内存中如何放置的?低位在前还是高位在前
查看>>
c语言中通过指针将数值赋值到制定内存地址
查看>>
64位与32位linux c开发时默认字节对齐值
查看>>
malloc(malloc在32位编译系统中分配的地址会8字节对齐,64为编译系统中会8或者16字节对齐)
查看>>
初始化时共享内存的key值和信号量初始化的key值可以一样
查看>>
linux创建线程之pthread_create
查看>>
pthread_attr_init线程通俗举例讲解与线程属性
查看>>
进程和线程的区别
查看>>
int main(int argc,char* argv[])详解,以及与int main()有什么区别
查看>>
SourceInsight全工程查找替换方法
查看>>
C语言chdir()函数:改变当前的工作目录
查看>>
Linux下的函数执行时间的统计方法(测试某个函数的执行时间)
查看>>
调整内核printk的打印级别(启动脚本中运行 echo 0 4 0 7 > /proc/sys/kernel/printk 关闭所有内核打印)
查看>>
临时关闭打开console办法
查看>>
Linux中gmtime和localtime的区别(time_t格式转换为tm格式)
查看>>
如果函数传递的是结构体,小心在调用的参数中给指针重新赋值(拿tm结构体举例)
查看>>
使用nm命令获取linux的可执行文件里或动态库中的所有函数名称
查看>>
动态库编写 头文件.h注意事项
查看>>
多个动态库的依赖问题(先后顺序务必注意)
查看>>