mysql密码重启_MySQL重置密码,重启服务

重置 root 用户密码

因为长时间未使用 MySql 导致忘记了 root 密码,现在将修改 root 用户密码的方法记录下来。

修改配置

vi /etc/my.cnf

在 [mysqld] 中添加skip-grant-tables

例如:

[mysqld]

skip-grant-tables

datadir=/var/lib/MySQL

socket=/var/lib/mysql/mysql.sock

重启mysql

service mysql restart

用户无密码登录

mysql -uroot -p (直接点击回车,密码为空)

选择数据库并修改密码

use mysql;

update user set authentication_string=password('123456') where user='root';

flush privileges;

删除并重启 mysql 服务

这个时候发现,确实可以用新的密码登录了, 但是操作的时候会提示:ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.。

这是因为少了一步修改导致,执行下面的命令进行修改:

alter user 'root'@'localhost' identified by 'youpassword';

执行的时候发现会提示一个新的报错:ERROR 1819 (HY000): Your password does not satisfy the current policy requirements,经过搜索,发现是因为密码有要求导致,可以选择使用一个包含大小写字母、数字和符号的密码,也可以选择更新一个简单的密码:

set global validate_password_policy=0;

这次密码的问题就彻底解决了。

报错 10060

除了可能是因为用户权限不足外,还有可能是服务器不允许请求 3306 端口,需要在服务器管理中,增加入站规则,允许 3306 端口即可。

具体的位置在:

服务器管理 => 高级安全 Windows 防火墙 => 入站规则 => 新建规则 => 端口3306 => 允许连接

清理连接数

在管理 MySQL 服务器的过程中,会出现连接时间过长的问题,分析之后发现主要是之前写的操作 MySQL 的程序未正常结束,导致资源占用过高。

这时可以使用以下的方案进行自理:

show status like 'Threads%';

show variables like '%max_connections%';

show global status like 'Max_used_connections';

show status;

show processlist;

show OPEN TABLES where In_use > 0;

这时可以找到真正占用数据库资源的进程,然后使用kill 结束掉进程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值