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
相关推荐
周杰伦的稻香4 分钟前
MySQL8.0+中引入的SET_USER_ID权限迭代SUPER权限指定 DEFINER
数据库·mysql
韩楚风2 小时前
【参天引擎】Cantian 服务端框架全景解析:进程架构、模块组成与交互关系
数据库·mysql·架构·cantian
vigor5124 小时前
MySQL通过Mango实现分库分表
android·数据库·mysql
KASH_SHADOW6 小时前
8-Mysql的安装与配置
数据库·mysql·adb
_陈陆亮9 小时前
MySQL 运维高频 SQL:一条语句快速定位长事务与锁阻塞
运维·sql·mysql
Full Stack Developme9 小时前
正则表达式设计及工作原理
数据库·mysql·正则表达式
谢慧琼9 小时前
免费版收银系统支持多账号同时登录吗?
mysql
rebibabo9 小时前
Java基础(24) | MySQL 原理与优化:事务、存储引擎、索引与锁
mysql··存储引擎·explain·视图·最左前缀·事务acid
渣渣灰飞11 小时前
MySQL 系统学习 第二阶段 SQL 第一章:DDL(Data Definition Language)
数据库·学习·mysql
じòぴé南冸じょうげん12 小时前
MySQL 8.0的密码被忘记了,怎么重置修改?
数据库·mysql