mac下启动mysql, 报错Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

本文解决了一个常见的问题:在Mac升级后,由于mysqld未启动导致的MySQL无法连接。通过在终端中运行mysqld命令,可以成功启动MySQL服务,并恢复正常连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前几天还可以登陆mysql, 今天竟然就登陆不上了, 报错Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2).

网上查找了一些资料, 发现是mac升级后, 导致mysqld没有启动, 从而出现这样的错误.

修复方法如下:

终端输入:  mysqld

2019-11-24T02:22:50.244065Z 0 [System] [MY-010116] [Server] /usr/local/Cellar/mysql/8.0.17_1/bin/mysqld (mysqld 8.0.17) starting as process 81400
2019-11-24T02:22:50.246827Z 0 [Warning] [MY-010159] [Server] Setting lower_case_table_names=2 because file system for /usr/local/var/mysql/ is case insensitive
2019-11-24T02:22:50.808617Z 0 [System] [MY-010229] [Server] Starting crash recovery...
2019-11-24T02:22:50.817542Z 0 [System] [MY-010232] [Server] Crash recovery finished.
2019-11-24T02:22:50.899899Z 0 [Warning] [MY-010068] [Server] CA certificate ca.pem is self signed.
2019-11-24T02:22:50.944323Z 0 [System] [MY-010931] [Server] /usr/local/Cellar/mysql/8.0.17_1/bin/mysqld: ready for connections. Version: '8.0.17'  socket: '/tmp/mysql.sock'  port: 3306  Homebrew.
2019-11-24T02:22:51.045745Z 0 [System] [MY-011323] [Server] X Plugin ready for connections. Socket: '/tmp/mysqlx.sock' bind-address: '::' port: 33060

mysqld启动, 生成/tmp/mysql.sock.

此时, 重新登陆mysql, 可正常连接.

### 解决 Mac 上无法通过 Socket 连接到本地 MySQL 服务器的问题 当遇到 `ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'` 的错误时,通常是因为 MySQL 服务未正常运行或者配置文件中的路径设置有误。以下是针对此问题的具体分析和解决方案: #### 1. 检查 MySQL 服务状态 确认 MySQL 是否已作为服务启动。如果服务未启动,则需要手动启动它。可以通过以下命令来检查并启动 MySQL 服务: ```bash sudo brew services start mysql ``` 上述命令适用于使用 Homebrew 安装的 MySQL 用户[^3]。 #### 2. 验证 Socket 文件位置 默认情况下,MySQLmacOS 中使用的 Unix Socket 路径可能是 `/tmp/mysql.sock` 或者 `/var/run/mysqld/mysqld.sock`。如果实际路径与预期不符,可以修改 MySQL 配置文件以匹配正确的路径。 编辑 MySQL 配置文件(通常是位于 `/etc/my.cnf` 或 `/usr/local/etc/my.cnf`),添加或更新如下内容: ```ini [mysqld] socket=/tmp/mysql.sock [client] socket=/tmp/mysql.sock ``` 保存更改后重启 MySQL 服务以应用新配置: ```bash sudo brew services restart mysql ``` #### 3. 手动创建 Symbolic Link 有时即使 MySQL 正常运行,Socket 文件也可能不存在于 `/tmp/` 下。此时可尝试创建一个符号链接指向实际存在的 Socket 文件。例如: ```bash ln -s /path/to/actual/socket/file /tmp/mysql.sock ``` 其中 `/path/to/actual/socket/file` 是由 `SHOW VARIABLES LIKE 'socket';` 查询返回的实际路径[^1]。 #### 4. 检查权限问题 确保当前用户拥有访问 `/tmp/mysql.sock` 及其父目录所需的适当权限。可通过调整文件权限修复潜在问题: ```bash chmod o+rwx /tmp chown _mysql:_mysql /tmp/mysql.sock ``` 以上操作完成后再次测试连接是否恢复正常。 --- ### 示例代码:验证 MySQL 当前配置 执行以下 SQL 命令获取当前 MySQL 使用的 Socket 文件路径: ```sql SHOW VARIABLES LIKE 'socket'; ``` ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值