linux忘记mysql密码找回方法

余生颓废 提交于 2020-03-18 13:58:44

方法一:

  # /etc/init.d/mysql stop

  # mysqld_safe --user=mysql --skip-grant-tables --skip-networking &

  # mysql -u root mysql

  mysql> update user set password=password('newpassword') where user='root';

  mysql> flush privileges;

  mysql> quit

  # /etc/init.d/mysql restart

  # mysql -uroot -p

  enter password: <输入新设的密码newpassword>

  mysql>

  方法二:

  直接使用/etc/mysql/debian.cnf文件中[client]节提供的用户名和密码:

  # mysql -udebian-sys-maint -p

  enter password: <输入[client]节的密码>

  mysql> update user set password=password('newpassword') where user='root';

  mysql> flush privileges;

  mysql> quit

  # mysql -uroot -p

  enter password: <输入新设的密码newpassword>

  mysql>

  方法三:

  # mysql -uroot -p

  enter password: <输入/etc/mysql/debian.cnf文件中[client]节提供的密码>

  方法四:

  方法如下: 1, 关闭mysql服务 /etc/init.d/mysqld stop 2,使用 –skip-grant-tables选项启动mysql服务,可以修 改/etc/inin.d/mysqld脚本启动位置增加此选项, vi /etc/init.d/mysqld

  方法如下:

  1, 关闭mysql服务

  /etc/init.d/mysqld stop

  2,使用 –skip-grant-tables选项启动mysql服务,可以修 改/etc/inin.d/mysqld脚本启动位置增加此选项,

  vi /etc/init.d/mysqld

  在下面运行启动的语句里增加--skip-grant-tables

  /usr/bin/mysqld_safe --skip-grant-tables --datadir="$datadir" --socket="$socketfile"

  --log-error="$errlogfile" --pid-file="$mypidfile"

  加入--skip-grant-tables的意思是启动mysql服务的时候跳 过权限表认证。启动后,连接到mysql的root不需要口令

  3,重新启动mysql服务

  /etc/init.d/mysqld start

  4. 修改root用户的密码;

  mysql> update mysql.user set password=password('123456') where user=root;

  mysql> flush privileges;

  mysql> quit

  5. 重新启动mysql,就可以使用 新密码登录了。

  mysql

  mysql -u root –p

  输入密码:123456

  6,关闭mysql服务

  /etc/init.d/mysqld stop

  7, 重新修改第2步修改的/etc/init.d/mysqld,使其保持原来不变,也就是取消--skip-grant-tables语句

  8,重新 启动mysql服务

  /etc/init.d/mysqld start

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!