mysql 报错 Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (2)

本文介绍了如何解决在Mac上遇到的MySQL连接错误'Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)'。问题可能由MySQL关键字变化引起,解决方案包括修改配置文件,删除特定关键字,处理权限问题,以及重启MySQL服务。

mysql 报错 Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)

Mac版, 数据库莫名报错

Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

尝试重新安装最新版本的数据库,8.0。并未解决。

解决方案:

1.cmd打开到mysql下:

cd /usr/local/mysql/bin

2.运行mysqld, 报错如下:

2021-12-23T06:25:39.163473Z 0 [ERROR] [MY-000077] [Server] /usr/local/mysql-8.0.27-macos11-x86_64/bin/mysqld: Error while setting value 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' to 'sql_mode'.
2021-12-23T06:25:39.163510Z 0 [ERROR] [MY-010119] [Server] Aborting
2021-12-23T06:25:39.163574Z 0 [Note] [MY-010120] [Server] Binlog end

3.初步定位是在设置值的时候,出现的了错误。

查看其他博客,定位问题在 Mysql 8.0以上已经取消了NO_AUTO_CREATE_USER这个关键字,windows 系统在mysql.ini中的sql_mode中删掉这个关键字即可; Mac系统,则找到 /etc/my.cnf,打开删除掉这个关键字即可。

4.到这一步,查看下问题解决了没有。如果没有,则继续。

bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

报错:

2021-12-23T06:27:04.364602Z 0 [ERROR] [MY-000077] [Server] /usr/local/mysql-8.0.27-macos11-x86_64/bin/mysqld: Error while setting value 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' to 'sql_mode'.
2021-12-23T06:27:04.364621Z 0 [ERROR] [MY-013236] [Server] The designated data directory data is unusable. You can remove all files that the server added to it.
2021-12-23T06:27:04.364680Z 0 [ERROR] [MY-010119] [Server] Aborting
2021-12-23T06:27:04.364776Z 0 [Note] [MY-010120] [Server] Binlog end

5.看报错信息, 我们需要删除data目录下的文件。这个目录的访问需要权限,如果需要,则su获取权限。

cd /usr/local/mysql/data

删除目录下的文件

rm -rf *

6.回退目录,继续执行

bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

输出:

2021-12-23T06:32:49.510459Z 0 [System] [MY-013169] [Server] /usr/local/mysql-8.0.27-macos11-x86_64/bin/mysqld (mysqld 8.0.27) initializing of server in progress as process 4099
2021-12-23T06:32:49.512814Z 0 [Warning] [MY-010159] [Server] Setting lower_case_table_names=2 because file system for /usr/local/mysql/data/ is case insensitive
2021-12-23T06:32:49.520416Z 1 [System] [MY-013576] [InnoDB] InnoDB initialization has started.
2021-12-23T06:32:49.674060Z 1 [System] [MY-013577] [InnoDB] InnoDB initialization has ended.
2021-12-23T06:32:50.271883Z 0 [Warning] [MY-013746] [Server] A deprecated TLS version TLSv1 is enabled for channel mysql_main
2021-12-23T06:32:50.271900Z 0 [Warning] [MY-013746] [Server] A deprecated TLS version TLSv1.1 is enabled for channel mysql_main
2021-12-23T06:32:50.440144Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: 5n6u22SD=z.#
2021-12-23T06:32:51.003939Z 0 [System] [MY-013172] [Server] Received SHUTDOWN from user <via user signal>. Shutting down mysqld (Version: 8.0.27).

生成了一个临时的密码 A temporary password is generated for root@localhost: 5n6u22SD=z.#

这个我并没有用到。

7.正常启动Mysql

mysql -u root -p

最后:

报错信息,很难做到完全的一致,毕竟涉及版本等等…

慢慢的逐步尝试排查,终会到达Rome

### 错误分析与解决方案 用户在尝试通过 Spark 连接 MySQL 时,遇到了错误 `Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)`。该问题通常与 MySQL 的配置或服务状态有关。 #### 1. 检查 MySQL 服务是否正常运行 确保 MySQL 服务已启动并正在运行。可以通过以下命令检查服务状态: ```bash systemctl status mysqld ``` 如果服务未启动,可以使用以下命令启动 MySQL 服务[^3]: ```bash systemctl start mysqld ``` #### 2. 配置 MySQL 的套接字路径 MySQL 默认的套接字文件路径可能为 `/var/lib/mysql/mysql.sock` 或 `/tmp/mysql.sock`。如果 Spark 使用的路径与 MySQL 实际的套接字路径不匹配,则会导致连接失败。 - **检查 MySQL 的实际套接字路径** 打开 MySQL 的配置文件(通常是 `/etc/my.cnf` 或 `/etc/mysql/my.cnf`),查找 `[mysqld]` 部分中的 `socket` 参数: ```ini [mysqld] socket=/var/lib/mysql/mysql.sock ``` 如果路径为 `/var/lib/mysql/mysql.sock`,但 Spark 配置中指定的是 `/tmp/mysql.sock`,则需要调整 Spark 的配置以匹配 MySQL 的实际路径。 - **修改 Spark 的 JDBC URL** 在 Spark 的 JDBC URL 中明确指定 MySQL 的套接字路径。例如: ```python jdbc_url = "jdbc:mysql://localhost:3306/your_database?serverTimezone=UTC&useSSL=false&socketFactory=com.mysql.cj.NativeSocketFactory&socket=/var/lib/mysql/mysql.sock" ``` #### 3. 确保 MySQL 监听了正确的网络接口 如果用户尝试通过远程 IP 地址连接 MySQL(如 `192.168.181.101`),需要确保 MySQL 配置了监听所有网络接口或特定的 IP 地址。 - **修改 MySQL 配置文件** 编辑 MySQL 的配置文件 `/etc/my.cnf`,找到 `[mysqld]` 部分,设置 `bind-address` 参数为 `0.0.0.0`,表示监听所有网络接口: ```ini [mysqld] bind-address=0.0.0.0 ``` - **重启 MySQL 服务** 修改配置后,重启 MySQL 服务以使更改生效: ```bash systemctl restart mysqld ``` #### 4. 检查防火墙和 SELinux 设置 如果 MySQL 服务已启动但仍然无法通过远程 IP 地址连接,可能是防火墙或 SELinux 阻止了访问。 - **检查防火墙规则** 确保 MySQL 的默认端口(3306)已被允许通过防火墙: ```bash firewall-cmd --permanent --add-port=3306/tcp firewall-cmd --reload ``` - **检查 SELinux 设置** 如果 SELinux 启用,可能会阻止 MySQL 的网络访问。可以临时禁用 SELinux 进行测试: ```bash setenforce 0 ``` #### 5. 验证 MySQL 用户权限 确保 MySQL 用户具有从远程主机连接的权限。可以通过以下 SQL 命令授予权限: ```sql GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'your_password' WITH GRANT OPTION; FLUSH PRIVILEGES; ``` ### 示例代码 以下是一个完整的 Spark 连接 MySQL 的示例代码: ```python from pyspark.sql import SparkSession spark = SparkSession.builder \ .appName("MySQL Connection Example") \ .getOrCreate() jdbc_url = "jdbc:mysql://localhost:3306/your_database?serverTimezone=UTC&useSSL=false&socketFactory=com.mysql.cj.NativeSocketFactory&socket=/var/lib/mysql/mysql.sock" properties = { "user": "root", "password": "your_password", "driver": "com.mysql.cj.jdbc.Driver" } df = spark.read.jdbc(url=jdbc_url, table="your_table", properties=properties) df.show() ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值