【MySQL】Linux Yum 安装 MySQL 8.x

本文写作目的是为了介绍如何在 Linux 上安装 MySQL 8.x ,当前 MySQL 通用发行版为 8.0.37 (官方建议用于生产环境),创新版本为 8.3.0 ,部分步骤随版本更新可能有所变化,以官方手册为准。

笔者使用的操作系统为 CentOS 7.8.2003 ,内核为 3.10.0-1160.80.1.el7.x86_64

bash 复制代码
$> cat /etc/centos-release
CentOS Linux release 7.8.2003 (Core)
$> uname -a
Linux ic-source 3.10.0-1160.80.1.el7.x86_64 #1 SMP Tue Nov 8 15:48:59 UTC 2022 x86_64 x86_64 x86_64 GNU/Linux

1、获取并安装 MySQL 8 Yum 源

bash 复制代码
$> wget https://dev.mysql.com/get/mysql80-community-release-el7-11.noarch.rpm
$> sudo rpm -ivh mysql80-community-release-el7-11.noarch.rpm
$> sudo yum makecache

安装 rpm 包时也可以使用 yum localinstall

bash 复制代码
$> sudo yum localinstall mysql80-community-release-el7-11.noarch.rpm

注释

本文中默认使用的操作系统用户为普通用户,拥有 sudo 权限;如直接使用 root 用户安装,则不需要使用 sudo ;如果未配置好 sudo 权限,请自行配置。

2、配置 Yum 源开关(可选)

设置 enabled=1 开启需要用的源,设置 enabled=0 关闭不需要的源。笔者因个人需求要用到 MySQL ConnectorMySQL Tools ,因而额外开启了它们。

bash 复制代码
$> sudo vi /etc/yum.repos.d/mysql-community.repo

[mysql80-community]
name=MySQL 8.0 Community Server
baseurl=http://repo.mysql.com/yum/mysql-8.0-community/el/7/$basearch
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022
       file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

[mysql-connectors-community]
name=MySQL Connectors Community
baseurl=http://repo.mysql.com/yum/mysql-connectors-community/el/7/$basearch
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022
       file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

[mysql-tools-community]
name=MySQL Tools Community
baseurl=http://repo.mysql.com/yum/mysql-tools-community/el/7/$basearch
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022
       file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

注意,此处的 file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022 一会如果报错会用到。

另外,也可以使用 yum-config-manager --(enable| disable) 来启动/关闭 repo 仓库。

bash 复制代码
$> sudo yum-config-manager --disable mysql57-community
$> sudo yum-config-manager --enable mysql80-community

3、安装 MySQL 8.x

笔者安装的是 MySQL 8.0.37 (其实是更新)。最近 MySQL 官方的 Yum 源下载速度有点慢。

bash 复制代码
$> yum install -y mysql-community-server

重要

安装或更新时(可能由于长时间未更新所致)可能会出现如下报错:

复制代码
Downloading packages:
warning: /var/cache/yum/x86_64/7/mysql80-community/packages/mysql-community->devel-8.0.36-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID a8d3785c: >NOKEY
从 file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022 检索密钥

可以看出是本地的 /etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022 出了问题,检查发现不存在该文件。所以需要下载下来。

参见 解决【获取 GPG 密钥失败:"Couldn't open file /etc/pki/rpm-gpg/RPM-GPG-KEY-mysql-2022"】

如无报错,则安装成功。

4、安装后启动 MySQL 服务器加以验证

正确配置 /etc/my.cnf 或其他选项文件。也可以以后再配置。本文不以详述。

启动 MySQL 服务器:

bash 复制代码
$> systemctl start mysqld

查看 MySQL 服务器状态:

bash 复制代码
$> systemctl status mysqld

第一次启动 MySQL 服务器时会进行初始化,如果服务器的数据目录为空,则会发生以下情况:

  • 服务器被初始化。

  • 在数据目录下生成 SSL 证书和秘钥文件。

  • validate_password 被安装并启用。

  • 创建了超级用户帐户 'root'@'localhost'。超级用户的密码已设置并存储在错误日志文件中。要显示它,请使用以下命令:

    复制代码
    $> sudo grep 'temporary password' /var/log/mysqld.log

    尽快使用生成的临时密码登录来更改 root 密码,并为超级用户帐户设置自定义密码:

    bash 复制代码
    $> mysql -uroot -p
    mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!';

也可以第一次手动启动 MySQL 服务器时使用 mysqld 程序的 --initialize-insecure 选项。该选项会创建默认数据库并退出,然后创建一个密码为空的超级用户。常用于自动化脚本大批量安装 MySQL 服务器。

注释

默认安装 validate_passwordvalidate_password 实现的默认密码策略要求密码至少包含一个大写字母、一个小写字母、一位数字和一个特殊字符,并且密码总长度至少为 8 个字符。

相关推荐
m0_613856292 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7942 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1372 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
j_xxx404_2 小时前
Linux:静态链接与动态链接深度解析
linux·运维·服务器·c++·人工智能
收获不止数据库2 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下3 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610263 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
_只道当时是寻常3 小时前
【Codex】Ubuntu 安装 Codex CLI 并解决 Clash 代理与账号认证问题
linux·ubuntu·chatgpt
Elastic 中国社区官方博客3 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
互联网推荐官4 小时前
上海软件定制开发全流程拆解:需求分析、技术选型与交付管理的工程实践
大数据·数据库·需求分析