一键安装|卸载 mysql 8.2.0 shell脚本

场景:为了在无网、外网 mysql 安装方便,这里分享一个自己编写得 shell脚本

  • 这里以当前最新版 mysql 8.2.0centos-7
    二进制包下载:
    下载地址

    mysql_install.sh
shell 复制代码
#!/bin/bash
# 解压安装包
tar -xf mysql-8.2.0-linux-glibc2.17-x86_64.tar.xz

# 移动解压后的文件夹到指定位置
mv mysql-8.2.0-linux-glibc2.17-x86_64 /usr/local/mysql

# 创建MySQL数据目录
mkdir -p /var/lib/mysql

# 创建MySQL组和用户
groupadd mysql
useradd -r -g mysql -s /bin/false mysql

# 修改文件夹权限
chown -R mysql:mysql /usr/local/mysql
chown -R mysql:mysql /var/lib/mysql

# 创建MySQL配置文件
cat > /usr/local/mysql/my.cnf << EOF
[mysqld]
basedir=/usr/local/mysql
datadir=/var/lib/mysql
server_id=1 
port=3306 

[mysql]
default-character-set=utf8mb4

[client]
port=3306
socket=/var/lib/mysql/mysqlx.sock
EOF

# 初始化MySQL
cd /usr/local/mysql
./bin/mysqld --defaults-file=/usr/local/mysql/my.cnf --initialize-insecure --user=mysql

# 创建MySQL服务
cat > /etc/systemd/system/mysql.service <<EOF
[Unit]
Description=MySQL8.2.0 Server
After=syslog.target
After=network.target

[Install]
WantedBy=multi-user.target

[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld_safe --defaults-file=/usr/local/mysql/my.cnf
EOF

# 启动MySQL服务并设置开机启动
systemctl daemon-reload
systemctl start mysql
systemctl enable mysql

mysql_remove.sh

shell 复制代码
#!/bin/bash

# 停止mysql服务
sudo systemctl stop mysql

# 删除mysql用户组
sudo userdel mysql
sudo groupdel mysql


# 删除mysql服务配置
sudo systemctl disable mysql
sudo rm /etc/systemd/system/mysql.service

# 删除数据文件
sudo rm -rf /var/lib/mysql

# 删除mysql二进制文件
sudo rm -rf /usr/local/mysql

echo "mysql已成功卸载!"
相关推荐
doubt。19 分钟前
【BUUCTF】[RCTF2015]EasySQL1
网络·数据库·笔记·mysql·安全·web安全
小辛学西嘎嘎1 小时前
MVCC在MySQL中实现无锁的原理
数据库·mysql
咩咩大主教4 小时前
Go语言通过Casbin配合MySQL和Gorm实现RBAC访问控制模型
mysql·golang·鉴权·go语言·rbac·abac·casbin
Deutsch.6 小时前
MySQL——主从同步
mysql·adb
猿小喵7 小时前
MySQL四种隔离级别
数据库·mysql
祁思妙想8 小时前
【LeetCode】--- MySQL刷题集合
数据库·mysql
m0_748248028 小时前
【MySQL】C# 连接MySQL
数据库·mysql·c#
东软吴彦祖10 小时前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
慵懒的猫mi10 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin
码农丁丁13 小时前
为什么数据库不应该使用外键
数据库·mysql·oracle·数据库设计·外键