uf123 发表于 2018-10-10 07:54:29

Mysql5.7忘记root密码及mysql5.7修改root密码的方法

  关闭正在运行的 MySQL :
  1
  # service mysql stop
  运行
  1
  # mysqld_safe --skip-grant-tables &
  为了安全可以这样禁止远程连接:
  1
  # mysqld_safe --skip-grant-tables --skip-networking &
  使用mysql连接server:
  1
  # mysql -p
  更改密码:
  1
  mysql> update mysql.user set authentication_string=password('1qaz2wsx') where user='root' and Host = 'localhost';
  更改密码之后要授权登录

  mysql>grant all privileges on *.* to 'root'@'localhost'>  root密码修改默认要修改两个地方,一个是localhost,一个是%(远程连接)。
  update mysql.user set authentication_string=password('1qaz2wsx') where user='root' and Host = '%';

  grant all privileges on *.* to 'root'@'%'>  两个账号密码都要修改才算完成。
  *特别提醒注意的一点是,新版的mysql数据库下的user表中已经没有Password字段了
  mysql优雅关闭
  mysqladmin -uroot -p-S /tmp/mysql.sock shutdown
  而是将加密后的用户密码存储于authentication_string字段
  1
  2
  mysql> flush privileges;
  mysql> quit;
  修改完毕。重启
  1
  # service mysql restart
  然后mysql就可以连接了
  但此时操作似乎功能不完全,还要alter user…
  1
  mysql> alter user 'root'@'localhost' identified by '123';
  这样也可以:
  1
  mysql> set password for 'root'@'localhost'=password('123');
  重点给大家介绍下mysql 5.7 root密码修改
  MySQL管理者密码设置或修改:
  依据官方说明5.6以后版本,第一次启动时会在root目录下生产一个随机密码,文件名.mysql_secret。
  1
  2
  3
  4
  5
  # cat /root/.mysql_secret
  # Password set for user 'root@localhost' at 2015-03-27 23:12:10
  :Jj+FTiqvyrF
  # cd /usr/local/mysql/bin/
  # ./mysqladmin -u root -h localhost password '123456' -p
  Enter password: #此行输入.mysql_secret里第二行内容
  1
  2
  mysqladmin: Using a password on the command line interface can be insecure.
  Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
  官方的方式,笔者无论是否使用--skip-grant-tables启动mysql都测试失败,亲们可以测试:
  1
  2
  shell>mysql -uroot -p'password' #password即.mysql_secret里的密码
  mysql>SET PASSWORD = PASSWORD('newpasswd');
  旧版本,安装后ROOT无密码,按如下操作:
  方法一:
  1
  2
  3
  4
  5
  6
  7
  shell>service mysqld stop #停止mysql服务
  shell>mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
  shell>mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
  mysql>use mysql;
  mysql>update user set password=PASSWORD("123456")where user="root"; #更改密码为 newpassord
  mysql>flush privileges; #更新权限
  mysql>quit #退出
  方法二:
  1
  2
  3
  4
  shell>service mysqld stop #停止mysql服务
  shell>mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
  shell>mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
  mysql > set password for root@localhost = password('mysqlroot');
  方法三:
  1
  shell>/path/mysqladmin -u UserName -h Host password 'new_password' -p
  本文出自 http://www.iyunv.net/article/77858.htm

页: [1]
查看完整版本: Mysql5.7忘记root密码及mysql5.7修改root密码的方法