1、mysql 普通用户连接报错: MySql server has gone away
2、进入mysql错误日志位置查看输出日志显示错误为:
[Warning] [MY-013130] [Server] Aborted connection 47 to db: 'unconnected' user: 'tjcx' host: '10.195.11.4' (init_connect command failed; diagnostics area: MY-001273 - Unknown collation: 'server')
错误原因: cd /etc/my.cnf:
数据库配置文件中参数配置错误:
应该将配置改成 init_connect = "SET NAMES utf8mb4 COLLATE utf8mb4_general_ci"
关于MySQL的初始化连接设置。SET NAMES utf8mb4 COLLATE
server=utf8mb4_general_ci
这一句是用于设置MySQL连接的字符集和排序规则。
在正常情况下,这个语句应该在连接MySQL数据库后执行。它告诉MySQL你希望使用的字符集和排序规则。utf8mb4
是字符集的名字,utf8mb4_general_ci
是排序规则的名字。
但是,这个语句中有一个小错误。在指定排序规则时,server=utf8mb4_general_ci
是不正确的。你可能想要使用COLLATE utf8mb4_general_ci
来指定排序规则。因此,正确的语句应该是:
sql`SET NAMES 'utf8mb4' COLLATE 'utf8mb4_general_ci';`
你可以在连接到MySQL后,直接运行这条语句来设置字符集和排序规则。如果你是在一个脚本中设置这个,那么应该在你的脚本开始处运行这个语句。如果你是在命令行中设置这个,那么应该在连接MySQL后,立即运行这个语句。