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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 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任何版本,如有问题,请大家随时联系我。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
关系型数据库 MySQL 数据库
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
|
7天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
63 24
|
1天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
39 7
|
20天前
|
关系型数据库 MySQL Linux
MySQL数据库下载安装教程(Windows&Linux)
本文档详细介绍了MySQL的安装步骤,包括安装前的准备工作、下载安装包、Windows和Linux系统下的具体安装流程,以及如何配置MySQL服务、设置环境变量、启动服务和连接数据库等关键操作。
|
1月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
|
26天前
|
网络安全 数据库
gbase 8a 数据库 安装8ampp 常见ssh报错问题
gbase 8a 数据库 安装8ampp 常见ssh报错问题
|
1月前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
184 0
|
2天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
10 3
|
2天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
14 3