Skip to content

安装部署

RHEL

在线安装

镜像源

bash
# 安装官方镜像源 
sudo yum install -y https://repo.mysql.com//mysql84-community-release-el9-1.noarch.rpm
sudo yum install -y https://repo.mysql.com//mysql84-community-release-el8-1.noarch.rpm
sudo yum install -y https://repo.mysql.com//mysql84-community-release-el7-1.noarch.rpm
# 卸载镜像源
yum -y remove mysql84-community-release
yum -y remove mysql80-community-release

替换镜像源

可选,当前貌似有问题

bash
# 替换网易镜像源
sed -i 's#https://repo.mysql.com/yum#https://mirrors.163.com/mysql/yum#g' /etc/yum.repos.d/mysql-community.repo
sed -i 's#https://repo.mysql.com/yum#https://mirrors.163.com/mysql/yum#g' /etc/yum.repos.d/mysql-community-source.repo
sed -i 's#https://repo.mysql.com/yum#https://mirrors.163.com/mysql/yum#g' /etc/yum.repos.d/mysql-community-debuginfo.repo

清理更新缓存

bash
sudo yum clean all && sudo yum makecache && sudo yum repolist

禁用系统默认模块

bash
sudo yum module disable mysql

查看当前已经安装模块

bash
sudo yum repolist all | grep mysql

启用指定模块

bash
# 启用长期支持版本
sudo yum-config-manager --disable mysql80-community
sudo yum-config-manager --disable mysql-connectors-community
sudo yum-config-manager --disable mysql-innovation-community
sudo yum-config-manager --disable mysql-tools-community
sudo yum-config-manager --enable mysql-8.4-lts-community
sudo yum-config-manager --enable mysql-tools-8.4-lts-community
# 启用创新版本
sudo yum-config-manager --disable mysql80-community
sudo yum-config-manager --disable mysql-8.4-lts-community
sudo yum-config-manager --disable mysql-tools-8.4-lts-community
sudo yum-config-manager --enable mysql-innovation-community
# 启用传统版本
sudo yum-config-manager --disable mysql-connectors-community
sudo yum-config-manager --disable mysql-innovation-community
sudo yum-config-manager --disable mysql-tools-community
sudo yum-config-manager --disable mysql-8.4-lts-community
sudo yum-config-manager --disable mysql-tools-8.4-lts-community
sudo yum-config-manager --enable mysql80-community

安装

bash
sudo yum install mysql-community-server

手工安装

把下载回来的压缩包上传到服务器临时目录下,解压缩后逐一安装。

bash
# 解压缩
tar xvf mysql-8.4.1-1.el9.x86_64.rpm-bundle.tar
# 安装
yum install -y mysql-community-common-8.4.1-1.el9.x86_64.rpm
yum install -y mysql-community-client-plugins-8.4.1-1.el9.x86_64.rpm
yum install -y mysql-community-libs-8.4.1-1.el9.x86_64.rpm
yum install -y mysql-community-client-8.4.1-1.el9.x86_64.rpm
yum install -y mysql-community-icu-data-files-8.4.1-1.el9.x86_64.rpm
yum install -y mysql-community-server-8.4.1-1.el9.x86_64.rpm

安装目录

|---data                    --      
|---|---app                 -- 应用目录    
|---|---|---data            -- 数据目录    
|---|---|---|---mysql       -- MySQL
|---|---|---|---|---data    -- MySQL数据目录
|---|---|---|---|---logs    -- MySQL日志目录
|---|---|---temp            -- 临时目录

初始化

初始化数据目录并授权。

bash
# 新建数据目录和日志目录 
mkdir -p /data/app/data/mysql/data
mkdir -p /data/app/data/mysql/logs
# 创建日志文件,这一步非必须
touch /data/app/data/mysql/logs/error.log
touch /data/app/data/mysql/logs/slow.log
touch /data/app/data/mysql/logs/general.log
# 赋予目录权限
sudo chown -R mysql.mysql /data/app/data/mysql/

打开配置文件

bash
sudo mv /etc/my.cnf /etc/my.cnf.bak
sudo touch /etc/my.cnf
sudo vi /etc/my.cnf

编辑内容如下

bash
[mysqld]
# 端口
port=3306
# 安装目录和数据目录
# basedir=/data/app/tools/mysql/server
datadir=/data/app/data/mysql/data
# 表名不区分大小写
lower_case_table_names=1
# 编码
character-set-server=utf8mb4
# 字符集
collation-server=utf8mb4_0900_ai_ci
# 指定时区
default-time-zone='+8:00'
# 最大连接数
max_connections=128
# 错误日志
log-error=/data/app/data/mysql/logs/mysql.log
# 慢查询
# 开启慢查询日志
slow-query-log=on
# 慢查询日志路径
slow_query_log_file=/data/app/data/mysql/logs/mysql-slow.log
# 修改为记录5秒内的查询,默认为记录10秒内的查询
long_query_time=5
# 记录未使用索引的查询
log-queries-not-using-indexes=on
#
sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION
[mysqldump]
max_allowed_packet=8M

启动服务

bash
sudo systemctl enable mysqld.service
sudo systemctl start mysqld.service
sudo systemctl stop mysqld.service
sudo systemctl restart mysqld.service
sudo systemctl disable mysqld.service
sudo systemctl status mysqld.service
sudo systemctl daemon-reload

修改默认密码

数据库启动初始化完成后,会生成一个临时的密码保存在/var/log/mysqld.log的日志文件里面。 所以第一次登录时需要查到这个临时密码,并使用临时密码登录后修改初始密码。

bash
# 自定义目录,按上面配置文件,需要从这里查找初始密码
grep 'temporary password' /data/app/data/mysql/logs/mysql.log
# 默认目录
grep 'temporary password' /var/log/mysqld.log
#
ALTER USER 'root'@'localhost' IDENTIFIED BY 'Root@007';

Windows

安装目录

bash
|---D                       --    
|---|---Tools               --  
|---|---|---MySQL           -- MySQL目录
|---|---|---|---Server      -- MySQL安装目录
|---|---|---|---Data        -- MySQL数据目录
|---|---|---|---Logs        -- MySQL日志目录
|---|---|---|---my.ini      -- 配置文件
|---|---|---temp            -- 临时目录

把绿色安装包解压缩到安装目录下,新建配置文件,内容参考如下

bash
[mysqld]
# 端口
port=3306
# 安装目录和数据目录
basedir=D:\Tools\MySQL\Server
datadir=D:\Tools\MySQL\Data
# 表名不区分大小写
lower_case_table_names=1
# 编码
character-set-server=utf8mb4
# 字符集
collation-server=utf8mb4_0900_ai_ci
# 指定时区
default-time-zone='+8:00'
# 启用传统密码策略认证
mysql_native_password=ON
# 错误日志
log-error=D:\Tools\MySQL\Logs\mysql.log
# 慢查询
# 开启慢查询日志
slow-query-log=on
# 慢查询日志路径
slow_query_log_file=D:\Tools\MySQL\Logs\mysql-slow.log
# 修改为记录5秒内的查询,默认为记录10秒内的查询
long_query_time=5
# 记录未使用索引的查询
log-queries-not-using-indexes=on
[mysqldump]
max_allowed_packet=8M

执行下面命令完成安装和系统服务配置

bash
# 初始化数据库
mysqld --initialize-insecure --datadir=D:\Tools\MySQL\Data
# 安装系统服务
mysqld --install MySQL --defaults-file=D:\Tools\MySQL\my.ini
# 手工启动服务
mysqld --defaults-file=D:\Tools\MySQL\my.ini
# 移除系统服务
mysqld –remove MySQL
# 启动
net start MySQL
# 停止
net stop MySQL

服务启动后,可以直接连,默认账号密码为空,这点跟RHEL有区别。

MacOS