CentOS8 安装 MySQL8.0(RPM)
- Mysql官网下载RPM包
- 卸载其他版本
- 检查是否安装过
- 卸载之前的安装
- 安装MySQL8.0
- 安装客户端(mysql-client)
- 安装服务端(mysql-server)
- 查看是否安装成功
- 初始化mysql
- 启动mysql服务
- /var/lib/mysql目录权限授权
- 重新启动mysql服务
- 查看初始化随机生成的root密码
- 安全设置
- 使用
- mysql登录
- 重置密码(Mysql8.0+有变化)
- 先把root的旧密码置空
- 重置成新密码
- 修改密码策略配置
- 重新修改密码
- 如何停止、重启和查看mysql服务
- mysql的相关安装目录文件
- /usr/bin //相关命令
- /usr/share/mysql-8.0/ //配置文件目录
- /var/lib/mysql //数据库文件存放目录
- /etc/my.cnf //mysql的启动配置文件
环境:Linux centos8 4.18.0-80.el8.x86_64、Mysql8.0.20-1
Mysql官网下载RPM包
直接下载链接:
mysql-community-server-8.0.20-1.el8.x86_64mysql-community-client-8.0.20-1.el8.x86_64.rpm
mysql-community-common-8.0.20-1.el8.x86_64.rpm
mysql-community-libs-8.0.20-1.el8.x86_64.rpm
卸载其他版本
检查是否安装过
[root@localhost work]# rpm -qa | grep -i mysql
[root@localhost work]#
卸载之前的安装
rpm -e --nodeps 软件名 //强力删除,对相关依赖的文件也进行强力删除
安装MySQL8.0
安装客户端(mysql-client)
rpm -ivh rpm包
- 安装mysql-community-common-8.0.20
- 安装mysql-community-libs-8.0.20
- 安装mysql-community-client-8.0.20(前两个是其依赖)
[root@localhost mysql8.0]# rpm -ivh mysql-community-common-8.0.20-1.el8.x86_64.rpm
warning: mysql-community-common-8.0.20-1.el8.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Verifying... ################################# [100%]
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-common-8.0.20-1.e################################# [100%]
[root@localhost mysql8.0]# rpm -ivh mysql-community-libs-8.0.20-1.el8.x86_64.rpm
warning: mysql-community-libs-8.0.20-1.el8.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Verifying... ################################# [100%]
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-libs-8.0.20-1.el8################################# [100%]
[root@localhost mysql8.0]# rpm -ivh mysql-community-client-8.0.20-1.el8.x86_64.rpm
warning: mysql-community-client-8.0.20-1.el8.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Verifying... ################################# [100%]
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-client-8.0.20-1.e################################# [100%]
[root@localhost mysql8.0]#
安装服务端(mysql-server)
rpm -ivh mysql-community-server-8.0.20-1.el8.x86_64.rpm --force --nodeps // --force --nodeps主要是解决这是由于yum安装了旧版本的GPG keys造成的error错误
[root@localhost mysql8.0]# rpm -ivh mysql-community-server-8.0.20-1.el8.x86_64.rpm
warning: mysql-community-server-8.0.20-1.el8.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
error: Failed dependencies:
net-tools is needed by mysql-community-server-8.0.20-1.el8.x86_64
[root@localhost mysql8.0]# rpm -ivh mysql-community-server-8.0.20-1.el8.x86_64.rpm --force --nodeps
warning: mysql-community-server-8.0.20-1.el8.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Verifying... ################################# [100%]
Preparing... ################################# [100%]
Updating / installing...
1:mysql-community-server-8.0.20-1.e################################# [100%]
[/usr/lib/tmpfiles.d/mysql.conf:23] Line references path below legacy directory /var/run/, updating /var/run/mysqld → /run/mysqld; please update the tmpfiles.d/ drop-in file accordingly.
[root@localhost mysql8.0]#
查看是否安装成功
有以下方式查看:
- ps -ef | grep mysql
- cat /etc/group | grep mysql
- cat /etc/password | grep mysql
- mysqladmin --version
[root@localhost mysql8.0]# ps -ef | grep mysql
root 2546 1327 0 22:56 pts/0 00:00:00 grep --color=auto mysql
[root@localhost mysql8.0]# cat /etc/group | grep mysql
mysql:x:27:
[root@localhost mysql8.0]# cat /etc/password | grep mysql
cat: /etc/password: No such file or directory
[root@localhost mysql8.0]# mysqladmin --version
mysqladmin Ver 8.0.20 for Linux on x86_64 (MySQL Community Server - GPL)
[root@localhost mysql8.0]#
初始化mysql
mysqld --initialize //创建数据文件目录和mysql系统数据库 产生随机root密码
[root@localhost mysql8.0]# mysqld --initialize
[root@localhost mysql8.0]#
启动mysql服务
systemctl start mysqld
[root@localhost mysql8.0]# systemctl start mysqld
Job for mysqld.service failed because the control process exited with error code.
See "systemctl status mysqld.service" and "journalctl -xe" for details.
[root@localhost mysql8.0]#
启动失败,因为/var/lib/mysql目录权限不够
[root@localhost mysql8.0]# ll /var/lib/mysql/
total 164280
-rw-r----- 1 root root 56 May 22 22:59 auto.cnf
-rw-r----- 1 mysql mysql 0 May 22 23:00 binlog.index
-rw------- 1 root root 1676 May 22 22:59 ca-key.pem
-rw-r--r-- 1 root root 1112 May 22 22:59 ca.pem
-rw-r--r-- 1 root root 1112 May 22 22:59 client-cert.pem
-rw------- 1 root root 1680 May 22 22:59 client-key.pem
-rw-r----- 1 root root 196608 May 22 22:59 '#ib_16384_0.dblwr'
-rw-r----- 1 root root 8585216 May 22 22:59 '#ib_16384_1.dblwr'
-rw-r----- 1 root root 5497 May 22 22:59 ib_buffer_pool
-rw-r----- 1 root root 12582912 May 22 22:59 ibdata1
-rw-r----- 1 root root 50331648 May 22 22:59 ib_logfile0
-rw-r----- 1 root root 50331648 May 22 22:59 ib_logfile1
drwxr-x--- 2 root root 6 May 22 22:59 '#innodb_temp'
drwxr-x--- 2 root root 143 May 22 22:59 mysql
-rw-r----- 1 root root 25165824 May 22 22:59 mysql.ibd
drwxr-x--- 2 root root 8192 May 22 22:59 performance_schema
-rw------- 1 root root 1676 May 22 22:59 private_key.pem
-rw-r--r-- 1 root root 452 May 22 22:59 public_key.pem
-rw-r--r-- 1 root root 1112 May 22 22:59 server-cert.pem
-rw------- 1 root root 1676 May 22 22:59 server-key.pem
drwxr-x--- 2 root root 28 May 22 22:59 sys
-rw-r----- 1 root root 10485760 May 22 22:59 undo_001
-rw-r----- 1 root root 10485760 May 22 22:59 undo_002
[root@localhost mysql8.0]#
/var/lib/mysql目录权限授权
chown -R mysql:mysql /var/lib/mysql/
[root@localhost mysql8.0]# chown -R mysql:mysql /var/lib/mysql/
[root@localhost mysql8.0]# ll /var/lib/mysql/
total 164280
-rw-r----- 1 mysql mysql 56 May 22 22:59 auto.cnf
-rw-r----- 1 mysql mysql 0 May 22 23:00 binlog.index
-rw------- 1 mysql mysql 1676 May 22 22:59 ca-key.pem
-rw-r--r-- 1 mysql mysql 1112 May 22 22:59 ca.pem
-rw-r--r-- 1 mysql mysql 1112 May 22 22:59 client-cert.pem
-rw------- 1 mysql mysql 1680 May 22 22:59 client-key.pem
-rw-r----- 1 mysql mysql 196608 May 22 22:59 '#ib_16384_0.dblwr'
-rw-r----- 1 mysql mysql 8585216 May 22 22:59 '#ib_16384_1.dblwr'
-rw-r----- 1 mysql mysql 5497 May 22 22:59 ib_buffer_pool
-rw-r----- 1 mysql mysql 12582912 May 22 22:59 ibdata1
-rw-r----- 1 mysql mysql 50331648 May 22 22:59 ib_logfile0
-rw-r----- 1 mysql mysql 50331648 May 22 22:59 ib_logfile1
drwxr-x--- 2 mysql mysql 6 May 22 22:59 '#innodb_temp'
drwxr-x--- 2 mysql mysql 143 May 22 22:59 mysql
-rw-r----- 1 mysql mysql 25165824 May 22 22:59 mysql.ibd
drwxr-x--- 2 mysql mysql 8192 May 22 22:59 performance_schema
-rw------- 1 mysql mysql 1676 May 22 22:59 private_key.pem
-rw-r--r-- 1 mysql mysql 452 May 22 22:59 public_key.pem
-rw-r--r-- 1 mysql mysql 1112 May 22 22:59 server-cert.pem
-rw------- 1 mysql mysql 1676 May 22 22:59 server-key.pem
drwxr-x--- 2 mysql mysql 28 May 22 22:59 sys
-rw-r----- 1 mysql mysql 10485760 May 22 22:59 undo_001
-rw-r----- 1 mysql mysql 10485760 May 22 22:59 undo_002
[root@localhost mysql8.0]#
重新启动mysql服务
systemctl start mysqld //启动
ps -ef | grep mysql //查看mysql服务
[root@localhost mysql8.0]# systemctl start mysqld
[root@localhost mysql8.0]# ps -ef | grep mysql
mysql 2680 1 6 23:12 ? 00:00:01 /usr/sbin/mysqld
root 2726 1327 0 23:12 pts/0 00:00:00 grep --color=auto mysql
[root@localhost mysql8.0]#
查看初始化随机生成的root密码
cat /var/log/mysqld.log | grep password
[root@localhost mysql8.0]# cat /var/log/mysqld.log | grep password
2020-05-22T14:59:39.740017Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: won-V%kYc1al
安全设置
用户root密码可不设置,后面回修改
mysql_secure_installation
[root@localhost mysql8.0]# mysql_secure_installation
Securing the MySQL server deployment.
Enter password for user root: //输入 won-V%kYc1al
The existing password for the user account root has expired. Please set a new password.
New password: // 输入新密码 won-V%kYc1al
Re-enter new password: // 输入新密码 won-V%kYc1al
VALIDATE PASSWORD COMPONENT can be used to test passwords
and improve security. It checks the strength of password
and allows the users to set only those passwords which are
secure enough. Would you like to setup VALIDATE PASSWORD component?
Press y|Y for Yes, any other key for No: y
There are three levels of password validation policy:
LOW Length >= 8
MEDIUM Length >= 8, numeric, mixed case, and special characters
STRONG Length >= 8, numeric, mixed case, special characters and dictionary file
Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0
Using existing password for root.
Estimated strength of the password: 100
Change the password for root ? ((Press y|Y for Yes, any other key for No) : No //是否需要修改root用户密码
Estimated strength of the password: 100
Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y //
By default, a MySQL installation has an anonymous user,
allowing anyone to log into MySQL without having to have
a user account created for them. This is intended only for
testing, and to make the installation go a bit smoother.
You should remove them before moving into a production
environment.
Remove anonymous users? (Press y|Y for Yes, any other key for No) : y // 是否删除匿名用户
Success.
Normally, root should only be allowed to connect from
'localhost'. This ensures that someone cannot guess at
the root password from the network.
Disallow root login remotely? (Press y|Y for Yes, any other key for No) : No // 是否禁止root远程连接
... skipping.
By default, MySQL comes with a database named 'test' that
anyone can access. This is also intended only for testing,
and should be removed before moving into a production
environment.
Remove test database and access to it? (Press y|Y for Yes, any other key for No) : y // 是否删除测试数据库
- Dropping test database...
Success.
- Removing privileges on test database...
Success.
Reloading the privilege tables will ensure that all changes
made so far will take effect immediately.
Reload privilege tables now? (Press y|Y for Yes, any other key for No) : y // 是否重新加载权限表
Success.
All done!
[root@localhost mysql8.0]#
使用
mysql登录
mysql -uroot -p
[root@localhost mysql8.0]# mysql -u root -p
Enter password: //输入 won-V%kYc1al
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 11
Server version: 8.0.20 MySQL Community Server - GPL
Copyright (c) 2000, 2020, 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>
重置密码(Mysql8.0+有变化)
先把root的旧密码置空
use mysql;
update user set authentication_string=’’ where user=‘root’;
备注:Mysql5.7+ password字段 已改成 authentication_string字段
MySQL8.0 忘记 root 密码下如何修改密码
mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> update user set authentication_string='' where user='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
重置成新密码
alter user ‘root’@‘localhost’ identified by ‘root’;
备注:Mysql8.0修改密码方式已有变化(此处是个坑,需要注意)
mysql> alter user 'root'@'localhost' identified by 'root';
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
mysql>
修改密码策略配置
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements 错误原因,版本8.0 默认设置密码不能相同于用户名
validate_password.check_user_name | ON // 校验密码不能等同于用户名
validate_password.policy | LOW // 设置低级别策略
validate_password.length | 4 // 设置最低长度为4
mysql> SHOW VARIABLES LIKE 'validate_password%';
+--------------------------------------+-------+
| Variable_name | Value |
+--------------------------------------+-------+
| validate_password.check_user_name | ON |
| validate_password.dictionary_file | |
| validate_password.length | 8 |
| validate_password.mixed_case_count | 1 |
| validate_password.number_count | 1 |
| validate_password.policy | LOW |
| validate_password.special_char_count | 1 |
+--------------------------------------+-------+
7 rows in set (0.00 sec)
mysql> set global validate_password.check_user_name=OFF;
Query OK, 0 rows affected (0.00 sec)
mysql> SHOW VARIABLES LIKE 'validate_password%';
+--------------------------------------+-------+
| Variable_name | Value |
+--------------------------------------+-------+
| validate_password.check_user_name | OFF |
| validate_password.dictionary_file | |
| validate_password.length | 4 |
| validate_password.mixed_case_count | 1 |
| validate_password.number_count | 1 |
| validate_password.policy | LOW |
| validate_password.special_char_count | 1 |
+--------------------------------------+-------+
7 rows in set (0.00 sec)
mysql>
重新修改密码
设置完密码策略后重新输入修改命令
mysql> alter user 'root'@'localhost' identified by 'root';
Query OK, 0 rows affected (0.01 sec)
如何停止、重启和查看mysql服务
systemctl stop mysqld //停止服务
systemctl restart mysqld //重启服务
systemctl status mysqld //查看服务
mysql的相关安装目录文件
/usr/bin //相关命令
[root@localhost mysql8.0]# ls /usr/bin/my*
/usr/bin/myisamchk /usr/bin/mysqlbinlog /usr/bin/mysqlpump
/usr/bin/myisam_ftdump /usr/bin/mysqlcheck /usr/bin/mysql_secure_installation
/usr/bin/myisamlog /usr/bin/mysql_config_editor /usr/bin/mysqlshow
/usr/bin/myisampack /usr/bin/mysqld_pre_systemd /usr/bin/mysqlslap
/usr/bin/my_print_defaults /usr/bin/mysqldump /usr/bin/mysql_ssl_rsa_setup
/usr/bin/mysql /usr/bin/mysqldumpslow /usr/bin/mysql_tzinfo_to_sql
/usr/bin/mysqladmin /usr/bin/mysqlimport /usr/bin/mysql_upgrade
[root@localhost mysql8.0]#
/usr/share/mysql-8.0/ //配置文件目录
[root@localhost mysql8.0]# ls /usr/share/mysql-8.0/
bulgarian french korean romanian
charsets german messages_to_clients.txt russian
czech greek messages_to_error_log.txt serbian
danish hungarian mysql-log-rotate slovak
dictionary.txt innodb_memcached_config.sql norwegian spanish
dutch install_rewriter.sql norwegian-ny swedish
english italian polish ukrainian
estonian japanese portuguese uninstall_rewriter.sql
[root@localhost mysql8.0]#
/var/lib/mysql //数据库文件存放目录
[root@localhost mysql8.0]# ls /var/lib/mysql/
auto.cnf client-cert.pem ibdata1 mysql private_key.pem undo_001
binlog.000001 client-key.pem ib_logfile0 mysql.ibd public_key.pem undo_002
binlog.index '#ib_16384_0.dblwr' ib_logfile1 mysql.sock server-cert.pem
ca-key.pem '#ib_16384_1.dblwr' ibtmp1 mysql.sock.lock server-key.pem
ca.pem ib_buffer_pool '#innodb_temp' performance_schema sys
[root@localhost mysql8.0]#
/etc/my.cnf //mysql的启动配置文件
[root@localhost mysql8.0]# cat /etc/my.cnf
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/8.0/en/server-configuration-defaults.html
[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove the leading "# " to disable binary logging
# Binary logging captures changes between backups and is enabled by
# default. It's default setting is log_bin=binlog
# disable_log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
#
# Remove leading # to revert to previous value for default_authentication_plugin,
# this will increase compatibility with older clients. For background, see:
# https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_default_authentication_plugin
# default-authentication-plugin=mysql_native_password
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
[root@localhost mysql8.0]#