MySQL 设置root密码报错:mysqladmin: connect to server at 'localhost' failed
1.安装完MySQL设置root密码报错如下
[root@vm172-31-0-6 data]# mysqladmin -uroot password "linux@123"
mysqladmin: connect to server at 'localhost' failed
error: 'Access denied for user 'root'@'localhost' (using password: NO)'
2.停止MySQL服务
[root@vm172-31-0-6 ~]# systemctl stop mysqld.service
3 安全模式启动
[root@vm172-31-0-6 mysql]# mysqld_safe --skip-grant-tables &
[1] 20777
[root@vm172-31-0-6 mysql]# 190315 01:43:28 mysqld_safe Logging to '/var/log/mysqld.log'.
190315 01:43:28 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
4 无密码root帐号登陆
[root@vm172-31-0-6 mysql]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.43-log MySQL Community Server (GPL)
Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> use mysql;
Database changed
5 手动update修改密码
mysql> update user set password=password("linux@123") where user='root' and host='localhost';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> quit
Bye
重新使用密码登录
[root@vm172-31-0-6 mysql]# mysql -uroot -plinux@123
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.6.43-log MySQL Community Server (GPL)
Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
6 正常重新启动
[root@vm172-31-0-6 ~]# service mysqld start
#查看进程
[root@vm172-31-0-6 ~]# ps -ef|grep mysql
root 19768 17076 0 01:37 pts/1 00:00:00 tail -f -n 300 /var/log/mysqld.log
mysql 27591 1 0 02:01 ? 00:00:00 /bin/sh /usr/bin/mysqld_safe --basedir=/usr
mysql 27820 27591 8 02:01 ? 00:00:00 /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/lib/mysql/mysql.sock
root 27849 27405 0 02:01 pts/2 00:00:00 grep --color=auto mysql
#查看端口号
[root@vm172-31-0-6 ~]# netstat -lntup|grep 3306
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 27820/mysqld
至此mysql密码修改完成。
-----------------------------------------要克服生活的焦虑和沮丧,得先学会做自己的主人-----------------------------------------