MySQL8.4 tar.xz安装

安装 MySQL 8.4

下载并解压 MySQL 8.4 安装包到 /opt 目录,创建符号链接以便后续管理:

bash 复制代码
useradd -r -s /bin/false mysql
cd /opt
tar xvf /tmp/mysql-8.4.9-linux-glibc2.28-x86_64.tar.xz
ln -s /opt/mysql-8.4.9-linux-glibc2.28-x86_64 /opt/mysql

配置环境变量,确保 MySQL 命令可执行:

bash 复制代码
vi ~/.bash_profile
export PATH=/opt/mysql/bin:$PATH

source ~/.bash_profile

创建安全目录结构

为数据、日志和文件导入导出操作创建专用目录,并设置正确的权限:

bash 复制代码
cd /data
mkdir -p /data/mysql_3306
chown mysql:mysql mysql_3306
cd mysql_3306
mkdir mysql-files data logs
chown mysql:mysql mysql-files data logs
chmod 750 mysql-files data logs

配置 MySQL 服务器选项

编辑配置文件 /data/mysql_3306/my.cnf,包含以下基本配置:

ini 复制代码
[mysqld]
server-id       =71013306
basedir         =/opt/mysql
datadir         =/data/mysql_3306/data
socket          =/data/mysql_3306/logs/mysql.sock
pid-file        =/data/mysql_3306/logs/mysql.pid
log-error       =/data/mysql_3306/logs/mysql_error.log
user            =mysql
port            =3306
secure_file_priv=/data/mysql_3306/mysql-files
local_infile=OFF

初始化数据目录并启动服务

使用 mysqld 初始化数据目录,注意记录生成的临时密码:

bash 复制代码
mysqld --defaults-file=/data/mysql_3306/my.cnf --initialize --user=mysql
grep "temporary password" /data/mysql_3306/logs/mysql_error.log

启动 MySQL 服务并连接到服务器:

bash 复制代码
mysqld --defaults-file=/data/mysql_3306/my.cnf --user=mysql &
mysql -S /data/mysql_3306/logs/mysql.sock -uroot -p

修改 root 用户密码:

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'mysql';

配置 systemd 服务管理

创建 systemd 服务文件 /usr/lib/systemd/system/mysqld.service

cd /usr/lib/systemd/system

touch mysqld.service

chmod 644 mysqld.service

ini 复制代码
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target

[Install]
WantedBy=multi-user.target

[Service]
User=mysql
Group=mysql
Type=notify
TimeoutSec=0
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/data/mysql_3306/my.cnf $MYSQLD_OPTS
EnvironmentFile=-/etc/sysconfig/mysql
LimitNOFILE = 10000
Restart=on-failure
RestartPreventExitStatus=1
Environment=MYSQLD_PARENT_PID=1
PrivateTmp=false

启用并启动 MySQL 服务:

bash 复制代码
systemctl enable mysqld.service
systemctl start mysqld
systemctl status mysqld
相关推荐
五阿哥永琪2 小时前
正则表达式
数据库·mysql·正则表达式
LaughingZhu2 小时前
Product Hunt 每日热榜 | 2026-06-13
数据库·mysql
sulikey3 小时前
数据库中等值连接与自然连接的区别。为什么不建议使用自然连接?
数据库·sql·mysql·等值连接·自然连接
huisheng_qaq4 小时前
【项目篇-01】Vmware虚拟机和环境安装配置
redis·mysql·canal·rocketmq·es·vaware虚拟机
承渊政道4 小时前
【MySQL数据库学习】(MySQL内置函数)
数据库·学习·mysql·ubuntu·bash·数据库开发·数据库系统
北顾笙98014 小时前
MySQL-day2
数据库·mysql
程序猿乐锅15 小时前
【MySQL | 第八篇】MySQL 视图
数据库·mysql
就叫_这个吧19 小时前
IDEA Mybatis xml文件,实现sql语句联想,自动填入补充
xml·mysql·intellij-idea·mybatis
北顾笙98020 小时前
MYSQL-day03
数据库·sql·mysql