当前位置: 首页 > news >正文

shell脚本自动安装MySQL8

  • 环境:centos7
  • 版本:8.0.28
  • 安装包:mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz 二进制包
  • 要求:安装包和shell脚本在同一目录下
  • 执行方式:sudo ./install_mysql8.sh
#!/bin/bash# 定义MySQL安装目录和压缩包名称MYSQL_DIR="/usr/local/mysql-8.0.28-linux-glibc2.12-x86_64"MYSQL_TAR="mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz"# 检查MySQL目录是否存在,不存在则解压并创建符号链接if [ ! -d "$MYSQL_DIR" ]; thenecho "正在解压MySQL安装包..."tar -xvf "$MYSQL_TAR" -C /usr/local/ln -s "$MYSQL_DIR" /usr/local/mysqlelseecho "MySQL安装包已存在,跳过解压。"fi# 检查MySQL用户是否存在,不存在则创建if ! id -u mysql >/dev/null 2>&1; thenecho "正在创建MySQL用户和组..."groupadd mysqluseradd -r -g mysql -s /bin/false mysqlelseecho "MySQL用户已存在,跳过创建。"fi# 检查MySQL配置文件是否存在,不存在则创建if [ ! -f /etc/mysql/my.cnf ]; thenecho "正在创建MySQL配置文件..."mkdir -p /etc/mysqlcat > /etc/mysql/my.cnf <<EOF[client]socket=/var/lib/mysql/mysql.sock[mysql]prompt=(\\u@\\h) [\\d]>\\_    # 更改MySQL客户端命令>前面显示内容[mysqld]port=3306user=mysqlsocket=/var/lib/mysql/mysql.sockdatadir=/usr/local/mysql/datalog_error=error.logEOFelseecho "MySQL配置文件已存在,跳过创建。"fi# 检查MySQL数据目录是否存在,不存在则初始化数据库if [ ! -d /usr/local/mysql/data ]; thenecho "正在初始化MySQL数据库..."cd /usr/local/mysqlmkdir -p mysql-fileschown mysql:mysql mysql-fileschmod 750 mysql-filesbin/mysqld --initialize --user=mysql# 获取临时root密码echo "等待MySQL生成临时密码..."for i in {1..30}; doif [ -f /usr/local/mysql/data/error.log ]; thentemp_password=$(grep 'temporary password' /usr/local/mysql/data/error.log | awk '{print $NF}')if [ -n "$temp_password" ]; thenecho "MySQL临时密码: $temp_password"breakfifisleep 1doneif [ -z "$temp_password" ]; thenecho "无法获取MySQL临时密码,请检查/usr/local/mysql/data/error.log"exit 1fielseecho "MySQL数据目录已存在,跳过初始化。"fi# 检查systemd服务文件是否存在,不存在则创建if [ ! -f /etc/systemd/system/mysqld.service ]; thenecho "正在创建systemd服务文件..."cat > /etc/systemd/system/mysqld.service <<EOF[Unit]Description=MySQL ServerAfter=network.target[Service]User=mysqlGroup=mysqlExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/mysql/my.cnfExecStop=/usr/local/mysql/bin/mysqladmin shutdownRestart=on-failure[Install]WantedBy=multi-user.targetEOFelseecho "systemd服务文件已存在,跳过创建。"fiif [ ! -d /var/lib/mysql/ ]; thenmkdir /var/lib/mysql/chown -R mysql:mysql /var/lib/mysqlchmod 750 /var/lib/mysqlelseecho "/var/lib/mysql目录已存在,跳过创建。"fi# 启动并启用MySQL服务systemctl daemon-reloadsystemctl start mysqldsystemctl enable mysqld# 配置环境变量if ! grep -q '/usr/local/mysql/bin' /etc/profile; thenecho 'export PATH=$PATH:/usr/local/mysql/bin' >> /etc/profile# 直接修改当前 Shell 的环境变量export PATH=$PATH:/usr/local/mysql/binecho "环境变量已添加到 /etc/profile 并立即生效。"echo "如需全局生效,请手动执行以下命令:"echo "source /etc/profile"elseecho "环境变量已配置,跳过。"fi# 检查MySQL是否安装成功if mysql --version >/dev/null 2>&1; thenecho "MySQL 8 安装成功!"elseecho "MySQL 安装失败,请检查日志。"exit 1fi
http://www.lryc.cn/news/536494.html

相关文章:

  • Git | 相关命令
  • RealClip正式发布:重新定义轻量化数字内容交互体验
  • Linux内核 - 非仿生机器人之感知主控系统(协议栈)
  • CZML 格式详解,javascript加载导出CZML文件示例
  • 【gRPC-gateway】auth-通过拦截器从上下文中提取元数据用于认证,与从http header转发待认证数据到上下文进行验证,go案例
  • Sass基础知识以及常用知识整理
  • Redis 内存回收机制
  • docker安装mongo,导入、导出数据
  • Excel常用操作
  • 嵌入式EasyRTC实时通话支持海思hi3516cv610,编译器arm-v01c02-linux-musleabi-gcc
  • 在freertos中,中断优先级和任务优先级之间的关系和使用方法
  • 设置ollama接口能外部访问
  • Go GUI 框架, energy many-browser 示例解读
  • Docker 部署 MongoDB | 国内阿里镜像
  • 软件工程-软件设计
  • Elasticsearch:15 年来致力于索引一切,找到重要内容
  • DeepSeek大模型一键部署解决方案:全平台多机分布式推理与国产硬件优化异构计算私有部署
  • Docker 部署 MySQL-5.7 单机版
  • 打破AI黑盒,拥抱开源力量:基于openGauss+DeepSeek的本地知识库,打造你的专属AI助手!
  • java配置api,vue网页调用api从oracle数据库读取数据
  • visual studio导入cmake项目后打开无法删除和回车
  • linux运行kettle 遇到问题汇总
  • 初识camel智能体(一)
  • 如何在Excel和WPS中进行翻译
  • TCP的拥塞控制
  • 【前端】几种常见的跨域解决方案代理的概念
  • C++之2048小游戏 第二期
  • Redis7——基础篇(一)
  • day9手机创意软件
  • C# Dictionary的实现原理