Linux系统上安装与配置 MySQL( CentOS 7 )

目录

[1. 下载并安装 MySQL 官方 Yum Repository](#1. 下载并安装 MySQL 官方 Yum Repository)

[2. 启动 MySQL 并查看运行状态](#2. 启动 MySQL 并查看运行状态)

[3. 找到 root 用户的初始密码](#3. 找到 root 用户的初始密码)

[4. 修改 root 用户密码](#4. 修改 root 用户密码)

[5. 设置允许远程登录](#5. 设置允许远程登录)

[6. 在云服务器配置 MySQL 端口](#6. 在云服务器配置 MySQL 端口)

[7. 关闭防火墙](#7. 关闭防火墙)

[8. 解决密码错误的问题](#8. 解决密码错误的问题)


前言

在 Linux 服务器上安装并配置 MySQL 是一项常见的任务,特别是当你需要远程管理数据库时。本文将详细介绍如何在 CentOS 7 上安装 MySQL、设置 root 用户密码以及配置允许远程登录。

1. 下载并安装 MySQL 官方 Yum Repository

首先,我们需要下载并安装 MySQL 的 Yum Repository,这样我们才能通过 yum 来安装 MySQL。

bash 复制代码
# 下载 MySQL 官方 Yum Repository
wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm

# 安装 MySQL Repository
rpm -ivh mysql-community-release-el7-5.noarch.rpm

# 安装 MySQL 服务
yum install mysql-community-server -y

2. 启动 MySQL 并查看运行状态

安装完成后,我们需要启动 MySQL 服务,并确认它正在运行。

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

# 查看 MySQL 服务的运行状态
systemctl status mysqld.service

3. 找到 root 用户的初始密码

在 MySQL 安装过程中,root 用户的密码默认会被随机生成。如果你不清楚密码,可以通过查看 MySQL 日志文件来获取它。

bash 复制代码
# 查找 MySQL 初始密码(可能为空)
grep "password" /var/log/mysqld.log

如果没有密码,或者你想为 root 用户设置一个新密码,接下来可以按照以下步骤操作。

4. 修改 root 用户密码

进入 MySQL 数据库后,可以通过以下命令修改 root 用户的密码。

bash 复制代码
# 登录 MySQL(如果没有密码,直接回车)
mysql -u root -p

# 创建一个新的 root 用户并设置密码
create user 'root'@'%' identified by 'qcBY@2021';

# 授予 root 用户所有权限
grant all privileges on *.* to 'root'@'%' with grant option;

# 刷新权限
flush privileges;

操作如下图:

注意: MySQL 默认启用了密码策略,要求密码必须由大小写字母、数字和特殊字符组成,且长度至少为 8 位。

5. 设置允许远程登录

在安装并配置完 MySQL 后,如果你想让 MySQL 支持远程登录,需要授予 root 用户远程访问权限。

复制代码
# 进入 MySQL 数据库
use mysql;

# 允许 root 用户从任何主机连接
grant all privileges on *.* to 'root'@'%' identified by 'qcBY@2021' with grant option;

# 刷新权限
flush privileges;

6. 在云服务器配置 MySQL 端口

MySQL 监听远程连接时所使用的端口默认为 3306。

下面以腾讯云为例,通过防火墙规则来开放此端口:

其他云服务器,例如阿里等,也都是类似的操作;

7. 关闭防火墙

如果防火墙阻止了 MySQL 连接,我们需要关闭防火墙或允许相应端口通过。

以下是关闭防火墙的命令:

复制代码
# 查看防火墙状态
service firewalld status;

# 关闭防火墙
systemctl stop firewalld

如果你不想关闭防火墙,也可以仅开放 MySQL 所需的端口:

复制代码
# 打开 MySQL 默认端口(3306)
firewall-cmd --permanent --zone=public --add-port=3306/tcp
firewall-cmd --reload

8. 解决密码错误的问题

有时候,安装 MySQL 后会遇到如下错误:

ERROR 1820 (HY000): You must reset your password using ALTER USER statement before

这个错误提示表明密码策略要求密码更复杂。你可以通过修改 MySQL 的密码验证策略来解决此问题。

复制代码
# 修改密码验证策略
mysql> set global validate_password_policy=0;

# 设置密码长度为 1(可根据需要修改)
mysql> set global validate_password_length=1;

# 然后可以修改密码
mysql> alter user 'root'@'localhost' identified by '123456';

总结

以上是如何在 Linux系统(CentOS 7) 上安装 MySQL、设置 root 用户密码并配置远程访问权限的完整步骤。通过这些操作,你可以成功启动 MySQL 服务并进行管理。确保密码策略符合要求,并根据需要调整防火墙设置以便远程访问。

相关推荐
摇滚侠6 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
bush47 小时前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5207 小时前
Linux 11 动态监控指令top
linux
麦聪聊数据8 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
不会C语言的男孩8 小时前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
ApacheSeaTunnel8 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_8 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
古城小栈8 小时前
Unix 与 Linux 异同小叙
linux·服务器·unix
DARLING Zero two♡8 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧9 小时前
Oracle EXPLAIN PLAN
数据库·oracle