快速部署MySQL 8.0:二进制安装全攻略

通用二进制格式安装 MySQL

安装相关包

bash 复制代码
[root@rocky9 ~]#yum  -y install libaio numactl-libs ncurses-compat-libs

创建用户和组

bash 复制代码
[root@rocky9 ~]#groupadd mysql
[root@rocky9 ~]#useradd -r -g mysql -s /bin/false mysql

准备程序文件

bash 复制代码
[root@rocky9 ~]#wget https://mirrors.aliyun.com/mysql/MySQL-8.0/mysql-8.0.28-linux-glibc2.12-x86_64.tar
[root@rocky9 ~]#tar xf mysql-8.0.28-linux-glibc2.12-x86_64.tar -C /usr/local/
[root@rocky9 ~]#cd /usr/local/
[root@rocky9 local]#ls
bin  games    lib    libexec                                     mysql-router-8.0.28-linux-glibc2.12-x86_64.tar.xz  sbin   src
etc  include  lib64  mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz  mysql-test-8.0.28-linux-glibc2.12-x86_64.tar.xz    share
[root@rocky9 local]#tar xf mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz 
[root@rocky9 local]#chown -R root:root /usr/local/mysql/

准备环境变量

bash 复制代码
[root@rocky9 ~]#echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh
[root@rocky9 ~]#. /etc/profile.d/mysql.sh 

准备配置文件

bash 复制代码
[root@rocky9 ~]#vim /etc/my.cnf
[mysqld]
datadir=/data/mysql
skip_name_resolve=1
socket=/data/mysql/mysql.sock        
log-error=/data/mysql/mysql.log
pid-file=/data/mysql/mysql.pid
[client]
socket=/data/mysql/mysql.sock

初始化数据库文件并提取root密码

bash 复制代码
#/data/mysql   会自动生成,但是/data/必须事先存在
#方式1:生产随机密码
[root@rocky9 ~]#mysqld --initialize --user=mysql --datadir=/data/mysql

#方式2: 生成 root 空密码
[root@rocky9 ~]#mysqld --initialize-insecure --user=mysql --datadir=/data/mysql

准备服务脚本和启动

bash 复制代码
[root@rocky9 ~]#vim /lib/systemd/system/mysqld.service
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)

[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql
PIDFile=/data/mysql/mysql.pid
ExecReload=/bin/kill -HUP $MAINPID
TimeoutSec=600
Restart=on-failure
RestartSec=5s
LimitNOFILE=10000

[Install]
WantedBy=multi-user.target

修改MySQL密码

bash 复制代码
#修改前面生成的随机密码为指定密码
mysqladmin -uroot -p'密码'   password caoge

#测试登录
mysql -uroot -pcaoge
相关推荐
神仙别闹2 分钟前
基于Java+MySQL实现(GUI)医院管理系统
java·mysql·oracle
betazhou9 分钟前
SQL server数据库镜像同步技术
数据库·sql server·高可用·数据库镜像
MXsoft61812 分钟前
**智能运维如何实现全栈监控与****AI****告警?****——****一体化平台实战解析**
运维·人工智能
mpHH16 分钟前
postgresql-分区表
数据库·postgresql
MXsoft61818 分钟前
**运维体系升级:筑牢企业数字化转型的稳定底座**
运维
MXsoft61826 分钟前
**一体化智能运维如何破解跨区域****IT****管理****难题****?**
运维
AC赳赳老秦39 分钟前
OpenClaw与WPS宏联动:批量执行WPS复杂操作,解决办公表格批量处理难题
java·前端·数据库·自动化·需求分析·deepseek·openclaw
源远流长jerry1 小时前
Linux 网络虚拟化深度解析:从 veth 设备对到容器网络实战
linux·运维·服务器·网络·性能优化·php
杜子不疼.1 小时前
用 JiuwenSwarm 搭建 SRE 智能值班体系:告警分级、根因分析与应急手册生成
数据库