如何在 CentOS 8 上安装 MySQL

MySQL 是世界上最流行的开源关系型数据库管理系统。
在默认的 CentOS 8 系统源仓库里,MySQL 数据库服务器最新可用的版本是 8.0。
MySQL 8.0 引进了很多新的特性和修改,因此,有些应用可能不能兼容这个版本。在选择安装哪个版本的 MySQL 时,请仔细翻阅应用(在你想要部署数据库的那台 CentOS 服务器上)的相关文档。
CentOS 8 同时还提供 MariaDB 10.3,它可以完美替代 MySQL 5.7,不过有一些限制。如果你的应用不兼容 MySQL 8.0,可以安装 MariaDB 10.3。
在这篇文章中,我们将会向你展示如何在 CentOS 8 系统上安全安装 MySQL 8.0。
一、在 CentOS 8 上安装 MySQL 8.0
以 root 或者其他有 sudo 权限的用户身份,通过使用 CentOS 包管理器来安装 MySQL 8.0 服务器:
sudo dnf install @mysql
@mysql
模块会安装 MySQL 和所有依赖安装包。
一旦安装完成,启动 MySQL 服务并且启用开机启动功能,运行下面的命令:
sudo systemctl enable --now mysqld
检查 MySQL 服务器是否正在运行,输入:
sudo systemctl status mysqld
● mysqld.service - MySQL 8.0 database server
Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)
Active: active (running) since Thu 2019-10-17 22:09:39 UTC; 15s ago
...
二、保护 MySQL
运行mysql_secure_installation
脚本,执行一些安全相关的操作,并且设置 MySQL root 用户密码:
sudo mysql_secure_installation
你将会被问到配置VALIDATE PASSWORD PLUGIN
,这个插件是用来测试 MySQL 用户的密码强度和提高安全性的。有三个密码安全级别,弱,中等,强。如果你不想设置密码验证插件,请直接按Enter
回车。
在下一个被提示的地方,你会被问到给 MySQL root 用户设置密码。一旦你操作完成,脚本将会要求你移除匿名用户,限制 root 用户访问本地机器,移除 test 测试数据库。你对于所有的问题都应该回到”Y“(yes)。
为了通过终端命令行与 MySQL 数据库交互,使用已经安装的 MySQL 客户端工具。测试 root 用户访问,输入:
mysql -u root -p
当被提示的时候,输入 root 用户密码,MySQL shell 将会展示如下:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 12
Server version: 8.0.17 Source distribution
就这些,你已经安装并且保护了在你的 CentOS 8 服务器上的 MySQL 8.0,你可以使用它了。
三、用户验证
CentOS 8 源仓库中的 MySQL 8.0 被设置采用古老的 mysql_native_password
用户验证插件,因为 CentOS 8 上的一些客户端工具和库不兼容caching_sha2_password
这个 标准 MySQL 8.0 默认采用的方法。
mysql_native_password
在大部分设置中都没问题。如果你想将默认的用户验证插件修改为更快更安全的caching_sha2_password
,打开下面的配置文件:
sudo vim /etc/my.cnf.d/mysql-default-authentication-plugin.cnf
将默认的default_authentication_plugin
修改为caching_sha2_password
:
[mysqld]
default_authentication_plugin=caching_sha2_password
关闭并且保存文件,同时重启 MySQL 服务器,使修改生效:
sudo systemctl restart mysqld
四、总结
CentOS 8 上提供 MySQL 8.0。这个安装通过简单输入dnf install @mysql
就可以完成。
现在你的 MySQL 服务器已经开启并运行了,你可以连接 MySQL shell,并且开始创建新的数据库和用户了。
如果你有任何疑问,请通过以下方式联系我们:
微信:

微信群: 加上面的微信,备注微信群
QQ: 3217680847

原文 :https://linuxize.com/post/how-to-install-mysql-on-centos-8/
版权声明:本作品采用知识共享署名-相同方式共享 4.0 国际许可协议进行许可。