ubuntu22,ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)的解决方法
翻遍了全网各种教程,既麻烦又无效,大多数是很多年前的方案。
喝了杯奶茶结果失眠了,一个通宵终于把这个傻*问题搞定了
问题描述:
我这里不再截图,口头描述:ubuntu22 配置完mysql后,在非root环境下执行mysql -u user -p 指令输完密码会报错,如标题。
解决方案:
最终解决与ChatGPT一起完成
- 在所有现成方案无效后,我选择完全重装mysql
# 卸载并清理
sudo apt-get purge mysql-*
sudo apt-get autoremove
sudo apt-get autoclean
# 删除配置和数据文件
sudo rm -rf /etc/mysql /var/lib/mysql
# 删除用户和组
sudo deluser mysql
sudo delgroup mysql
# 更新软件缓存
sudo apt-get update
# 安装mysql
sudo apt-get install mysql-server
# 启动,设置自启动
sudo systemctl start mysql
sudo systemctl enable mysql
在这里,我们先执行 sudo mysql 进入mysql设置root用户
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
然后执行mysql_secure_installation 脚本
sudo mysql_secure_installation
根据自己情况进行配置,我是个人学习开发,选择的最简单配置
这时mysql基本就弄好了,尝试执行mysql -u root -p,仍然有同样错误。
- 修改配置部分
首先检查mysql是否在正确运行,无异常接着往下做
检查 MySQL 套接字文件权限:确保 MySQL 套接字文件的权限允许 MySQL 客户端访问。通常,套接字文件位于 /var/run/mysqld/ 或 /tmp/ 目录中。你可以检查套接字文件的权限,以确保它们可读写。
检查 MySQL 客户端配置:有时,MySQL 客户端配置可能包含错误的套接字文件路径。你可以查看 MySQL 客户端的配置文件(通常是 ~/.my.cnf 或 /etc/mysql/my.cnf)并确保其中没有指定错误的套接字路径。
我选择在~/下创建了.my.cnf ,将/etc/mysql/my.cnf的内容复制过来,添加
[client] socket=/var/run/mysqld/mysqld.sock
保存退出,这份配置将覆盖其他的。
至此已完成,在非root环境下可以正常进入mysql