腾讯云Centos7.6使用yum安装MySQL8

1. 安装 MySQL 8

添加 MySQL Yum 仓库

bash 复制代码
# 下载 MySQL 8 的 yum 源
wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm

# 安装 yum 源
sudo rpm -ivh mysql80-community-release-el7-3.noarch.rpm

安装 MySQL 8

bash 复制代码
# 安装 MySQL 服务器
sudo yum install mysql-community-server -y

如果遇到类似错误:

bash 复制代码
Retrieving key from file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
Importing GPG key 0x5072E1F5:
 Userid     : "MySQL Release Engineering <mysql-build@oss.oracle.com>"
 Fingerprint: a4a9 4068 76fc bd3c 4567 70c8 8c71 8d3b 5072 e1f5
 Package    : mysql80-community-release-el7-3.noarch (installed)
 From       : /etc/pki/rpm-gpg/RPM-GPG-KEY-mysql


Public key for mysql-community-common-8.0.46-1.el7.x86_64.rpm is not installed


 Failing package is: mysql-community-common-8.0.46-1.el7.x86_64
 GPG Keys are configured as: file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

请使用下面命令

bash 复制代码
# 方法1:重新安装,跳过GPG检查
sudo yum install mysql-community-server -y --nogpgcheck

2. 启动 MySQL 并获取临时密码

bash 复制代码
# 启动 MySQL 服务
sudo systemctl start mysqld

# 设置开机自启
sudo systemctl enable mysqld

# 查看临时密码(MySQL 8 安装后会生成临时密码)
sudo grep 'temporary password' /var/log/mysqld.log

3. 修改 MySQL 密码

bash 复制代码
# 使用临时密码登录 MySQL
mysql -u root -p

登录后执行以下 SQL 命令:

sql 复制代码
-- 修改密码策略(可选,如果希望设置简单密码)
-- 查看当前密码策略
SHOW VARIABLES LIKE 'validate_password%';

-- 降低密码策略(可选)
SET GLOBAL validate_password.policy = LOW;
SET GLOBAL validate_password.length = 6;

-- 修改 root 密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';

-- 刷新权限
FLUSH PRIVILEGES;

4. 配置远程连接

sql 复制代码
-- 创建远程访问用户
CREATE USER 'root'@'%' IDENTIFIED BY '你的密码';

-- 授予所有权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

-- 或者只授予特定数据库权限
-- GRANT ALL PRIVILEGES ON database_name.* TO 'root'@'%';

-- 刷新权限
FLUSH PRIVILEGES;

-- 查看用户权限
SELECT host, user, plugin FROM mysql.user;

修改 MySQL 配置文件允许远程连接

bash 复制代码
# 编辑 MySQL 配置文件
sudo vim /etc/my.cnf

[mysqld] 部分修改或添加:

ini 复制代码
[mysqld]
# 允许远程连接
bind-address = 0.0.0.0
# 或者注释掉 bind-address
# bind-address = 127.0.0.1

配置防火墙

bash 复制代码
# 开放 3306 端口
sudo firewall-cmd --permanent --add-port=3306/tcp
sudo firewall-cmd --reload

# 或者直接关闭防火墙(不推荐)
# sudo systemctl stop firewalld
# sudo systemctl disable firewalld

重启 MySQL 服务

bash 复制代码
sudo systemctl restart mysqld

5. 验证远程连接

从其他机器测试连接:

bash 复制代码
mysql -h 服务器IP地址 -u root -p

注意事项

  1. 密码安全 :MySQL 8 默认使用 caching_sha2_password 认证插件,某些客户端可能不支持。如需兼容旧客户端:
sql 复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你的密码';
  1. SELinux 问题:如果连接失败,可能需要配置 SELinux:
bash 复制代码
# 查看 SELinux 状态
getenforce

# 临时关闭(不推荐)
sudo setenforce 0

# 或添加 SELinux 策略允许 MySQL 远程连接
sudo setsebool -P httpd_can_network_connect_db 1
  1. 云服务器:如果是云服务器(阿里云、腾讯云等),需要在安全组中放行 3306 端口。

完成以上步骤后,你的 MySQL 8 就可以远程连接了!

相关推荐
这个DBA有点耶1 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵1 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
SamDeepThinking2 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
李白客3 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
Jim6005 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL6 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
云技纵横9 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二9 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐9 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops