腾讯云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 就可以远程连接了!

相关推荐
yyk的萌1 小时前
创建属于自己的mysql的mcp
mysql·adb·ai·mcp
仙俊红1 小时前
如何优化 MySQL 深分页 SQL
android·sql·mysql
超梦dasgg1 小时前
工作中 MySQL 读写分离主从延迟:成因、影响、落地方案、生产实战处理
数据库·mysql
疯狂热爱代码的00后2 小时前
入门必看! MySQL增删改查全套示例SQL 直接复制运行
mysql
huipeng9262 小时前
企业级微服务开发实战(二):微服务基础设施搭建与中间件部署
java·redis·mysql·spring cloud·微服务·nacos·rabbitmq
可乐ea2 小时前
【知识获取与分享社区项目 | 项目日记第 24 天】终章总结:从认证、发布、计数、Feed、搜索到 RAG:完整复盘一个知识社区后端系统
java·spring boot·redis·mysql·elasticsearch·ai·kafka
小小编程路3 小时前
MySQL9.0|融合向量的新一代关系数据库安装配置教程
mysql
林小卫很行3 小时前
Obsidian 入门58:用 Remotely Save + 腾讯云 COS 实现多端同步
人工智能·云计算·腾讯云·知识管理·obsidian
不会就选b12 小时前
MySQL之视图
数据库·mysql