在基于RPM的Linux发行版上安装MySQL的推荐方法是使用Oracle提供的RPM包。对于MySQL社区版,有两种获取来源:
1、从MySQL软件源:
MySQLYum源、MySQLSLES源都能获取
2、从MySQL开发人员专区的下载MySQL社区服务器页面。
MySQL的RPM发行包也可能由其他供应商提供。请注意,它们在特性、功能和约定(包括通信设置)方面可能与Oracle构建的不同,并且本手册中的安装说明不一定适用于它们。应参考供应商的说明。
MySQL RPM 包
表2.8MySQL社区版RPM包
包名称 | 摘要 |
---|---|
mysql-community-client |
MySQL客户端应用程序和工具 |
mysql-community-client-plugins |
MySQL客户端应用程序的共享插件 |
mysql-community-common |
服务器和客户端库的通用文件 |
mysql-community-devel |
MySQL数据库客户端应用程序的开发表头文件和库 |
mysql-community-embedded-compat |
MySQL服务器作为嵌入式库,兼容使用该库版本18的应用程序 |
mysql-community-icu-data-files |
MySQL打包MySQL正则表达式所需的ICU数据文件 |
mysql-community-libs |
MySQL数据库客户端应用程序的共享库 |
mysql-community-libs-compat |
以前MySQL安装的共享兼容性库;仅当平台支持以前的MySQL版本时才存在 |
mysql-community-server |
数据库服务器和相关工具 |
mysql-community-server-debug |
调试服务器和插件二进制文件 |
mysql-community-test |
MySQL服务器的测试套件 |
mysql-community |
源代码 RPM 的文件名通常类似于 mysql-community-8.4.3-1.el7.src.rpm,具体取决于你选择的操作系统版本。 |
Additional *debuginfo* RPMs | 一些debuginfo 包: mysql-community-client-debuginfo, mysql-community-libs-debuginfo mysql-community-server-debug-debuginfo mysql-community-server-debuginfo, and mysql-community-test-debuginfo. |
表2.9MySQL企业版RPM包
包名称 | 摘要 |
---|---|
mysql-commercial-backup |
MySQL企业备份 |
mysql-commercial-client |
MySQL客户端应用程序和工具 |
mysql-commercial-client-plugins |
MySQL客户端应用程序的共享插件 |
mysql-commercial-common |
服务器和客户端库的通用文件 |
mysql-commercial-devel |
MySQL数据库客户端应用程序的开发表头文件和库 |
mysql-commercial-embedded-compat |
MySQL服务器作为嵌入式库,兼容使用该库版本18的应用程序 |
mysql-commercial-icu-data-files |
MySQL打包MySQL正则表达式所需的ICU数据文件 |
mysql-commercial-libs |
MySQL数据库客户端应用程序的共享库 |
mysql-commercial-libs-compat |
以前MySQL安装的共享兼容性库;仅当平台支持以前的MySQL版本时才存在。库的版本与您使用的分布默认安装的库版本相匹配。 |
mysql-commercial-server |
数据库服务器和相关工具 |
mysql-commercial-test |
MySQL服务器的测试套件 |
Additional *debuginfo* RPMs | 一些 debuginfo 包: mysql-commercial-client-debuginfo, mysql-commercial-libs-debuginfo mysql-commercial-server-debug-debuginfo mysql-commercial-server-debuginfo, and mysql-commercial-test-debuginfo. |
RPM的全名具有以下格式:
bash
packagename-version-distribution-arch.rpm
distribution
和*arch
*值表示Linux发行版和构建包的处理器类型。
表2.10MySQL Linux RPM包发行版本定义
发行版 | 预期使用 |
---|---|
el*{version} * 其中*{version} * 是主要的企业Linux版本,例如基于el8 |
EL6(8.0)、EL7、EL8和EL9的平台(例如,OracleLinux、Red Hat EnterpriseLinux和CentOS的相应版本) |
fc*{version} * 其中*{version} * 是主要的Fedora版本,例如fc37 |
Fedora 39、40和41 |
sl5 |
SUSELinuxEnterprise Server 15 |
要查看RPM包(例如mysql-community-server
)中的所有文件,请使用以下命令:
bash
$> rpm -qpl mysql-community-server-version-distribution-arch.rpm
本节其余部分的讨论仅适用于使用直接从Oracle下载而不是通过MySQL存储库下载的rpm包的安装过程。
某些包之间存在依赖关系。如果您计划安装许多包,您可能希望下载RPM包tar文件,其中包含上面列出的所有rpm包,因此您无需单独下载它们。
在大多数情况下,您需要安装mysql-community-server
、mysql-community-client
、mysql-community-client-plugins
、mysql-community-libs
、mysql-community-icu-data-files
、mysql-community-common
和mysql-community-libs-compat
包,以获得功能完整的标准MySQL安装。要执行这种标准的基本安装,请转到包含所有这些包的文件夹(最好不要有其他具有相似名称的rpm包),并发出以下命令:
bash
$> sudo yum install mysql-community-{server,client,client-plugins,icu-data-files,common,libs}-*
对于SLES,将yum替换为zypper,对于Fedora,将dnf替换为。
虽然最好使用像yum这样的高级包管理工具来安装包,但喜欢直接rpm命令的用户可以用rpm-Uvh命令替换yum install命令;然而,由于安装过程可能会遇到潜在的依赖问题,使用rpm-Uvh会使安装过程更容易失败。
要仅安装客户端程序,可以跳过要安装的包列表中的mysql-community-server
;发出以下命令:
bash
$> sudo yum install mysql-community-{client,client-plugins,common,libs}-*
对于SLES,将yum替换为zypper,对于Fedora,将dnf替换为。
一个使用rpm包标准的MySQL安装会在系统目录下创建文件和资源,如下表所示。
表2.11MySQL 安装布局(适用于 Linux RPM 包)
文件或资源 | 位置 |
---|---|
客户端程序和脚本 | /usr/bin |
mysqld服务 | /usr/sbin |
配置文件 | /etc/my.cnf |
数据目录 | /var/lib/mysql |
错误日志文件 | 对于RHEL, Oracle Linux, CentOS or Fedora 平台: /var/log/mysqld.log 对于SLES平台: /var/log/mysql/mysqld.log |
secure_file_priv的值 | /var/lib/mysql-files |
System V的初始化脚本 | 对于RHEL, Oracle Linux, CentOS or Fedora 平台: /etc/init.d/mysqld 对于SLES平台: /etc/init.d/mysql |
Systemd 服务名称 | 对于RHEL, Oracle Linux, CentOS or Fedora 平台: mysqld 对于SLES平台: mysql |
Pid文件 | /var/run/mysql/mysqld.pid |
Socket文件 | /var/lib/mysql/mysql.sock |
秘钥目录 | /var/lib/mysql-keyring |
Unix 帮助手册 | /usr/share/man |
包含的(头) 文件 | /usr/include/mysql |
lib库 | /usr/lib/mysql |
其他支持文件(例如,错误消息和字符集文件) | /usr/share/mysql |
安装还会在系统上创建一个名为mysql
的用户和一个名为mysql
的组。
如果使用useradd命令的-r
和-s /bin/false
选项创建的mysql
用户,该用户对服务器主机没有登录权限。要在操作系统上切换到mysql
用户,请使用--shell=/bin/bash
命令的su选项:
bash
$> su - mysql --shell=/bin/bash
- 使用旧软件包安装以前版本的MySQL可能会创建一个名为
/usr/my.cnf
的配置文件。强烈建议您检查文件的内容并将里面所需的设置迁移到文件/etc/my.cnf
文件,然后删除/usr/my.cnf
。
MySQL不会在安装过程结束时自动启动。对于Red Hat EnterpriseLinux、OracleLinux、CentOS和Fedora系统,请使用以下命令启动MySQL:
bash
$> systemctl start mysqld
对于SLES系统,命令相同,但服务名称不同:
bash
$> systemctl start mysql
如果操作系统启用了systemd,则应使用标准systemctl(或者参数反转的service)命令(例如stop、start、status和restart)来管理MySQL服务器服务。mysqld
服务默认启用,并在系统重新启动时启动。
在使用rpm和deb包的升级安装过程中,如果MySQL服务器正在运行,升级程序会首先停止MySQL服务器,然后执行升级,升级完成后重新启动MySQL服务器。例外情况:如果在升级过程中 MySQL 的版本类型发生了变化(例如,从社区版升级到企业版,或反之),则 MySQL 服务器不会自动重启。在这种情况下,你需要在升级后手动重启 MySQL 服务器,以确保所有更改生效。
在服务器初次启动时,如果服务器的数据目录为空,会发生以下情况:
1、初始化服务器
2、在数据目录中生成SSL证书和密钥文件
3、安装validate_password并启用
4、超级用户帐户'root'@'localhost'被
创建。生成超级用户的临时密码并存储在错误日志文件中。要显示密码,请对RHEL、OracleLinux、CentOS和Fedora系统使用以下命令:
bash
$> sudo grep 'temporary password' /var/log/mysqld.log
对SLES系统使用以下命令:
bash
$> sudo grep 'temporary password' /var/log/mysql/mysqld.log
下一步是使用生成的临时密码登录,并为超级用户帐户设置自定义密码:
bash
$> mysql -uroot -p
sql
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!';
validate_password默认安装。validate_password实现的默认密码策略要求密码至少包含一个大写字母、一个小写字母、一个数字和一个特殊字符,并且密码总长度至少为8个字符。
如果在安装过程中出现问题,您可能会在错误日志文件/var/log/mysqld.log
中找到调试信息。
对于某些Linux发行版,可能需要增加mysqld可用文件描述符的数量限制。
安装多个 MySQL 版本的客户端库
可以安装多个版本的客户端库,例如在你需要保持与基于旧库编译的旧应用程序的兼容性时。要安装旧版本的客户端库,可以使用 rpm 的 --oldpackage 选项。例如,要在已经安装了来自 MySQL 8.0 的 libmysqlclient.21 的 EL6 系统上安装 mysql-community-libs-5.5,可以使用如下命令:
bash
$> rpm --oldpackage -ivh mysql-community-libs-5.5.50-2.el6.x86_64.rpm
**调试包。**带有调试功能的MySQL Server的特殊变体已编译到服务器中的rpm包。它执行调试和内存分配检查,并在服务器运行时生成跟踪文件。要使用该调试版本,你可以使用 /usr/sbin/mysqld-debug 来启动 MySQL,而不是通过服务管理工具(如 systemctl 或 service)或使用标准的 /usr/sbin/mysqld 命令。mysqld-debug 是一个调试版本的 MySQL 服务器二进制文件,通常用于开发和调试目的,它提供了更多的调试信息和功能。
默认插件目录是/usr/lib64/mysql/plugin/debug,可配置plugin_dir。
从源SRPM重建RPM。MySQL的源代码SRPM包可供下载。它们可以按原样使用标准rpmbuild工具链重建MySQLRPM。