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
    评论
"Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)" 是一个错误提示,它表示无法通过指定的socket连接到本地的MySQL服务器。这个错误通常出现在使用PHP连接MySQL数据库时。我们可以通过以下方法解决这个问题: 1. 确认MySQL服务器是否正在运行。可以使用以下命令来检查MySQL服务器的运行状态: ``` systemctl status mysql ``` 2. 确认MySQL服务器是否使用了正确的socket路径。通过检查MySQL配置文件中的socket路径来确认,配置文件的位置通常是`/etc/mysql/mysql.conf.d/mysqld.cnf`。 3. 如果socket路径配置正确,但仍然出现错误,可以尝试手动创建socket文件。使用以下命令可以创建socket文件: ``` sudo touch /tmp/mysql.sock ``` 4. 如果手动创建socket文件后仍然无法解决问题,可以尝试修改MySQL配置文件中的socket路径,将其指向正确的位置。确保修改后重新启动MySQL服务。 总结起来,要解决"Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)"的问题,我们需要确认MySQL服务器是否运行,检查配置文件中的socket路径是否正确,并尝试手动创建socket文件。如果问题仍然存在,可以尝试修改配置文件并重新启动MySQL服务。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Can't connect to local MySQL server through socket](https://blog.csdn.net/qq_35462323/article/details/105024596)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Can’t connect to local MySQL server through socket解决方法](https://blog.csdn.net/weixin_34112900/article/details/93854948)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值