MySql错误合集

标签: 无 分类: 未分类 创建时间:2021-07-14 01:51:05 更新时间:2025-01-17 10:39:22

1.null, message from server: “Host ‘10.0.0.1’ is blocked because of many connection errors; unblock with ‘mysqladmin flush-hosts’”

主要是因为同一个ip在短时间内产生太多(超过mysql数据库max_connection_errors的最大值)中断的数据库连接而导致的阻塞

【解决方法】
方法一:临时解决问题

1
2
3
4
5
6
## 查找mysqladmin命令位置
whereis mysqladmin
## 进行mysqladmin路径
cd /usr/bin
## 执行
mysqladmin flush-hosts

方法二:修改配置

1
2
3
4
5
6
7
8
9
## 登录mysql
mysql

## 查询
mysql> show variables like "max_connections";
mysql> show variables like "max_connect_errors";
## 设置
mysql> SET GLOBAL max_connect_errors=10000;
mysql> set global max_connections = 200;
参考文章:
1.unblock with ‘mysqladmin flush-hosts’错误处理 mysqladmin flush-hosts
2.mysql 连接出错 ‘mysqladmin flush-hosts’ 提高允许的max_connection_errors数量,使用 flush-hosts 命令。
3.Linux查看mysql 安装路径和运行路径 查看mysql安装路径:whereis mysql
4.How to unblock with mysqladmin flush hosts
5.mysql连接flush-hosts问题处理 登录数据库,直接使用 mysql> flush hosts; 命令,这个方法对我不奏效,出现了错误:ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘-hosts’ at line 1

2.message from server: “Host ‘_gateway’ is not allowed to connect to this MySQL server”

MySQL 8.0

1
2
3
4
5
mysql -u root -p 

mysql> use mysql;
mysql> update user set host = '%' where user ='root';
mysql> flush privileges;

3.启动失败

我在Docker中安装了MySQL,启动不了了。

日志文件:

1
vi /var/log/mysqld.log

有用的信息显示:Data Dictionary initialization failed.

【解决】

1
2
3
4
5
6
7
8
9
10
## 查看配置
vi /etc/my.cnf
## 删除文件夹
rm -rf /var/lib/mysql
## 初始化
mysqld --initialize --console
## 目录授权
chown -R mysql:mysql /var/lib/mysql/
## 启动mysql
systemctl start mysqld

4.Access denied for user ‘root’@’localhost’ (using password: YES)

5.Can not perform keyring migration : Invalid –keyring-migration-source option.

[尝试]
mysqld命令是MySQL的主程序,用来安装初始化;mysql是MySQL的命令行工具;这里因为命令敲成了mysqld -u root -p导致的,正确的命令应该是mysql -uroot -p

6.Cannot invoke “java.util.Map.get(Object)” because “this.serverVariables” is null

【解决方法】
MySQL版本(我的是8.0.17)和数据库驱动版本不符合造成,升级mysql数据库驱动就可以了。

7.Authentication plugin ‘cache_sha2_password’ cannot be loaded

本来我想着要修改密码的,后来我解决方法就是换了一个Dbeaver,重新尝试了。

参考文章:
【1】.解决Authentication plugin ‘caching_sha2_password‘ cannot be loaded问题 解决问题方法有两种,一种是升级navicat驱动(博主用的是navicat是19年装的了,其他软件同理),另一种是把mysql用户登录密码加密规则还原成mysql_native_password。

8.ERROR 1524 (HY000): Plugin ‘mysql_native_password’ is not loaded

小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。