ubuntu22,ERROR 2002 Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’解决方法

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一起完成

  1. 在所有现成方案无效后,我选择完全重装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,仍然有同样错误。

  1. 修改配置部分

首先检查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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值