MySQL数据库一键安装脚本,适合任何版本

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL数据库一键安装脚本,适合任何版本

一、安装包和脚本准备:

下载所需的安装包上传至任务目录下,这里我以8.0.33版本为例,安装包大家自行去MySQL官网下载。

官网地址:https://dev.mysql.com/downloads/mysql/

  1. 链接: https://pan.baidu.com/s/10KFBi40h2oGURQTm9Z9IvQ
  2. 提取码: dgex

二、安装:

编辑好脚本,赋予脚本执行权限,然后source执行脚本。只需要输入自己所需要的版本号即可轻松完成数据库的安装。

  1. [root@localhost ~]#chmod +x mysql_install.sh
  2. [root@localhost ~]#source mysql_install.sh

三、脚本:

  1. #!/bin/bash
  2. echo "-----------------------------开始MYSQL安装--------------------------------------"
  3. start_time=$(date +%s)
  4. echo -e "\e[31m***************一键安装mysql任何版本数据库******************\e[0m"
  5. echo -e "输入安装版本,如\e[31m8.0.27\e[0m"
  6. read version
  7. find / -name mysql | xargs rm -rf
  8. port=$(netstat -antup|grep mysql|wc -l)
  9. if [ $port != 0 ]
  10. then echo "mysql进程存在,请先杀掉进程"
  11. ps -ef |grep mysqld
  12. exit 1
  13. fi
  14. echo "-----------------创建所需目录及用户并上传安装包----------------------------"
  15. # 获取当前所在目录位置
  16. current_dir=$(pwd)
  17. echo "当前所在目录位置: $current_dir"
  18. # 目标路径
  19. target_dir="/opt"
  20. # 检查目标路径是否存在,如果不存在则创建
  21. if [ ! -d "$target_dir" ]; then
  22.    mkdir -p "$target_dir"
  23.    echo "已创建目录: $target_dir"
  24. fi
  25. # 移动当前目录下的所有文件到目标路径
  26. mv $current_dir/* $target_dir
  27. echo "已将当前目录下所有文件移动至 $target_dir"
  28. mkdir -p  /data/mysql
  29. groupadd mysql
  30. useradd -r -g mysql mysql
  31. cd /opt/
  32. tar -xvf mysql-$version-linux-glibc2.12-x86_64.tar.xz
  33. mv mysql-$version-linux-glibc2.12-x86_64/  /usr/local/
  34. cd /usr/local/
  35. mv mysql-$version-linux-glibc2.12-x86_64/ mysql
  36. chown -R mysql.mysql /usr/local/mysql/
  37. echo "-----------------------------卸载原有的mysql组件--------------------------"
  38. yum list installed | grep mariadb
  39. yum -y remove mariadb*
  40. yum remove mariadb*
  41. chown mysql:mysql -R /data/mysql
  42. touch /etc/my.cnf
  43. chmod 644 /etc/my.cnf
  44. MYSQL_ROOT_PASSWORD=123456
  45. cat <<EOF >/etc/my.cnf
  46. [mysqld]
  47. user=mysql
  48. basedir=/usr/local/mysql
  49. datadir=/data/mysql
  50. socket=/tmp/mysql.sock
  51. log-error=/data/mysql/mysql.err
  52. pid-file=/data/mysql/mysql.pid
  53. server_id=1
  54. port=3306
  55. character-set-server=utf8
  56. innodb_rollback_on_timeout = ON
  57. character-set-server = utf8
  58. collation-server=utf8_general_ci
  59. sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
  60. lower_case_table_names=1
  61. max_connections=10000
  62. sync_binlog=1
  63. binlog_format=row
  64. log-bin=mysql-bin
  65. expire_logs_days=30
  66. [mysql]
  67. socket=/tmp/mysql.sock
  68. default-character-set=utf8
  69. [client]
  70. EOF
  71. echo "-----------------------------------初始化数据库-----------------------------------"
  72. cd /usr/local/mysql/bin
  73. ./mysqld --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql/ --datadir=/data/mysql/ --user=mysql --initialize
  74. cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
  75. path=$(grep 'MYSQL_HOME' /etc/profile|wc -l)
  76. if [ $path !=  0 ]
  77.  then
  78.    echo -e "\e[31m MYSQL_HOME路径存在\e[0m"
  79.  else
  80.    echo "export MYSQL_HOME=/usr/local/mysql/bin" >> /etc/profile
  81.    echo "export PATH=\$PATH:\$MYSQL_HOME"        >> /etc/profile
  82.    source /etc/profile
  83. fi
  84. echo "---------------------------------启动MYSQL服务---------------------------------------"
  85. service mysql start
  86. echo 'export PATH=$PATH:/usr/local/mysql/bin:/usr/local/mysql/lib'>>/etc/profile
  87. sleep 3
  88. source /etc/profile
  89. cat /data/mysql/mysql.err|grep password
  90. chkconfig --add mysql
  91. chkconfig mysql on
  92. chkconfig --list mysql
  93. echo "-----------------------------恭喜!MYSQL安装成功--------------------------------------"
  94. end_time=$(date +%s)
  95. execution_time=$((end_time - start_time))
  96. echo "脚本执行时间:${execution_time} 秒"
  97. MYSQL_OLDPASSWORD=`awk '/A temporary password/{print $NF}' /data/mysql/mysql.err`
  98. mysqladmin  -uroot -p${MYSQL_OLDPASSWORD} password ${MYSQL_ROOT_PASSWORD}
  99. mysql -uroot -p123456 -e "update mysql.user set host ='%' where user ='root';"
  100. mysql -uroot -p123456 -e "flush privileges;"
  101. mysql -uroot -p123456

说明:此脚本适用于mysql任何版本,如有问题,请大家随时联系我。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
15天前
|
弹性计算 关系型数据库 MySQL
centos7 mysql安装及配置
本文详细介绍了在阿里云服务器ECS上通过yum源安装MySQL 8.0.12的过程,包括更新yum源、下载并安装MySQL源、解决安装过程中可能遇到的问题等步骤。此外,还介绍了如何启动MySQL服务、设置开机自启、配置登录密码、添加远程登录用户以及处理远程连接异常等问题。适合初学者参考,帮助快速搭建MySQL环境。
94 8
centos7 mysql安装及配置
|
11天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
1天前
|
监控 关系型数据库 MySQL
如何升级mysql的版本
如何升级mysql的版本
10 2
|
1天前
|
存储 监控 关系型数据库
如何升级MySQL版本?
如何升级MySQL版本?
6 2
|
10天前
|
关系型数据库 分布式数据库 数据库
开源云原生数据库PolarDB PostgreSQL 15兼容版本正式发布
PolarDB进行了深度的内核优化,从而实现以更低的成本提供商业数据库的性能。
|
21天前
|
存储 关系型数据库 MySQL
实战!MySQL主从复制一键搭建脚本分享
实战!MySQL主从复制一键搭建脚本分享
27 2
|
21天前
|
关系型数据库 MySQL Linux
Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
【8月更文挑战第23天】Linux环境安装MySQL8.0.36使用rpm包安装,安装顺序是什么?
117 1
|
21天前
|
关系型数据库 MySQL 网络安全
全网首例!MySQL8 MGR多主一键搭建脚本分享
全网首例!MySQL8 MGR多主一键搭建脚本分享
20 1
|
8天前
|
关系型数据库 Java MySQL
"解锁Java Web传奇之旅:从JDK1.8到Tomcat,再到MariaDB,一场跨越数据库的冒险安装盛宴,挑战你的技术极限!"
【9月更文挑战第6天】在Linux环境下安装JDK 1.8、Tomcat和MariaDB是搭建Java Web应用的关键步骤。本文详细介绍了使用apt-get安装OpenJDK 1.8、下载并配置Tomcat,以及安装和安全设置MariaDB(MySQL的开源分支)的方法。通过这些步骤,您可以快速构建一个稳定、高效的开发和部署环境,并验证各组件是否正确安装和运行。这为您的Java Web应用提供了一个坚实的基础。
24 0
|
18天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~