本文主要记录如何在 Linux 中安装 MySQL。

环境:CentOS 7.6

MySQL 版本:5.7.39

1. 卸载已经安装了的 MySQL 或者 MariaDB

# 查看是否安装了 MariaDB
rpm -qa | grep mariadb
# 如果有就卸载
yum -y remove mariadb-libs-5.5.56-2.el7.x86_64

2. 下载 MySQL

官网链接:MySQL :: Download MySQL Community Server (Archived Versions)

我这里版本选择 5.7.39,操作系统选择 Red Hat Enterprise Linux / Oracle Linux,往下翻找到 mysql-5.7.39-el7-x86_64.tar.gz 点击后面的 Download 按钮下载即可。

3. 上传并解压

下载下来后使用 ftp 工具将压缩包上传到服务器的 /usr/local/env/mysql/ 目录下,切换到该目录下并解压:

cd /usr/local/env/mysql/

tar -zxvf mysql-5.7.39-el7-x86_64.tar.gz

# 为了方便记忆将其重命名
mv mysql-5.7.39-el7-x86_64 mysql5.7.39

4. 配置 MySQL

进入到 MySQL 安装目录中:

4.1. 创建一个 data 目录用于存放数据文件

mkdir data

4.2. 创建系统用户组和用户

# 查看所有用户组信息是否存在 mysql 组,不存在则创建,存在则直接新建用户
cat /etc/group | grep mysql
# 如果不存在则新建一个 mysql 组
groupadd mysql
# 查看是否存在 mysql 用户
cat /etc/passwd | grep mysql
# 没有则新建 mysql 用户
useradd -g mysql mysql

4.3. 修改 MySQL 安装目录的所有权(不是访问权限)

# 修改 MySQL 安装目录及其包含的所有文件所有权归 mysql 组中的 mysql 用户所有
chown -R mysql:mysql /usr/local/env/mysql/mysql5.7.39/

4.4. 初始化 MySQL 数据库

在 MySQL 安装目录下执行以下命令:

# 将 mysql.server 文件拷贝到 /etc/init.d 目录下并重命名为 mysqld
cp ./support-files/mysql.server /etc/init.d/mysqld

# 初始化
./mysqld --initialize --user=mysql --basedir=/usr/local//usr/local/env/mysql/mysql5.7.39 --datadir=/usr/local/env/mysql/mysql5.7.39/data

注意后面有初始密码,记下来!!!

这里我的初始密码为:czb&Mgn#W32X

4.5. [可选步骤]配置 my.cnf

从版本 5.7.18 开始,MySQL 免安装版二进制包中就不包含该文件了,即不需要 my.cnf 文件也可以正常运行;my.cnf 文件中配置的选项会在命令行启动 MySQL 的时候作为参数进行启动, 如果只是单纯的搭建一个 MySQL 实例,可以直接忽略此步骤。如果是搭建 MySQL 主从环境则需要该文件。这里就是用默认的不进行配置。

4.6. 修改 mysqld 文件

vim /etc/init.d/mysqld

按键盘 i 键进行编辑。将配置文件开头的 basedirdatadir 两项配置分别修改为你的 MySQL 安装目录以及前面创建的 data 目录绝对路径。

# 这两项配置根据自己 MySQL 安装位置自行修改
basedir=/usr/local/env/mysql/mysql5.7.39

datadir=/usr/local/env/mysql/mysql5.7.39/data

然后按 Esc 退出编辑,再按 shift + :输入 wq ! 保存并退出即可。

4.7. 设置 MySQL 开机启动

cd /etc/init.d
chkconfig --add mysqld

至此 MySQL 就已经安装完毕了,接下来就是使用命令启动 MySQL。

5. 启动 MySQL

service mysqld start

6. 配置 MySQL 环境变量

vim /etc/profile

在文档的最后面添加如下内容,不要带空格:

export PATH=$PATH:/usr/local/env/mysql/mysql5.7.39/bin

保存文档后执行如下命令使配置文件立即生效:

source /etc/profile

7. 重启 MySQL 服务,并且使用默认的 root 用户登录

这里就需要用到前面记下来的初始密码了。

# 重启 mysql 服务
service mysqld restart

mysql -u root -p
# 注意:输入密码时不会显示,输入完成回车即可

登录成功命令行则会变为 mysql>

8. 修改 root 用户的密码并且刷新。

mysql> alter user 'root'@'localhost' identified by '新密码';
Query OK, 0 rows affected (0.00 sec)

# MySQL 新设置用户或更改密码后需用 flush privileges 刷新 MySQL 的系统权限相关表
# 否则会出现拒绝访问,还有一种方法,就是重新启动 MySQL 服务器,来使新设置生效
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

设置完成后 CTRL + C 即可退出 mysql 命令行。

此时 MySQL 数据库只能在本机上使用 mysql 命令进行登录,还无法使用 navicat 等数据库可视化工具进行远程登录。

9. 设置允许 root 用户远程连接数据库

mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> update user set user.Host='%' where user.User='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

最后还需要开放 3306 端口号或者关闭防火墙, 如果是阿里云/腾讯云服务器则设置安全组即可。