您的当前位置:首页正文

Mariadb之密码修改

2024-11-29 来源:个人技术集锦

默认情况下,新安装的 mariadb 的密码为空,在shell终端直接输入 mysql 就能登陆数据库。

如果是刚安装第一次使用,请使用 mysql_secure_installation 命令初始化。

修改密码

知道原密码情况下修改密码

1.直接在shell命令行使用 mysqladm 命令修改。

mysqladmin -uroot -poldpassword password newpassword

2.登陆数据库修改密码。

mysql -uroot -p

2.1 更新 mysql 库中 user 表的字段:

MariaDB [(none)]> use mysql;
MariaDB [mysql]> UPDATE user SET password=password(‘newpassword’) WHERE user=‘root’;
或者
MariaDB [mysql]> ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘newpassword’;
MariaDB [mysql]> flush privileges;
MariaDB [mysql]> exit;

2.2 或者,使用 set 指令设置root密码:

MariaDB [(none)]> SET password for ‘root’@‘localhost’ = password(‘newpassword’);
MariaDB [(none)]> exit; # 加粗样式

忘记了 root 密码,则需要以跳过授权的方式启动 mariadb 来修改密码

systemctl stop mariadb

  1. 使用跳过授权的方式启动 mariadb。

mysqld_safe --skip-grant-tables & [1] 1441

[root@centos7 ~]# 170531 02:10:28 mysqld_safe Logging to ‘/var/log/mariadb/mariadb.log’.
170531 02:10:28 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
#ps -ef | grep 1441
root 1441 966 0 02:10 pts/0 00:00:00 /bin/sh /usr/bin/mysqld_safe --skip-grant-tables
mysql 1584 1441 0 02:10 pts/0 00:00:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --user=mysql --skip-grant-tables --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock

  1. 当跳过授权启动时,可以不需要密码直接登陆数据库。登陆更新密码即可。

mysql

MariaDB [(none)]> use mysql;
MariaDB [mysql]> UPDATE user SET password=password(‘newpassword’) WHERE user=‘root’;
MariaDB [mysql]> flush privileges;
MariaDB [mysql]> exit;

4、关闭跳过授权启动的进程

kill -9 1441

5、正常启动 mariadb:

systemctl start mariadb

显示全文