【linux】分享一个安装mysql的脚本

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

之前 写了个 426.【数据库】centos 7系统,二进制方式安装mysql ,很喜欢用二进制装mysql的方法,现在这个需求又出来了,我要装一个mysql在服务器上,于是乎,就想着这次把整个安装步骤,写出一个脚本出来。


直接上脚本:

#!/bin/bash
#Program:
#   setup mysql
#History:
#2023/02/26 junfenghe.cloud@qq.com  version:0.0.1
path=/bin:/sbin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:~/bin
export path
if [ -n "$1" ]
then
    echo "mysql will be installed in $1"
else
    echo "Please input path which mysql will be installed."
    echo "eg: $0 /usr/local"
    exit -1
fi
type 'mysql'
if [ $? -eq 0 ]
then
    echo 'mysql has installed'
    echo 'please uninstall mysql such as: check /var/lib/mysql  && /etc/profile && /etc/init.d/mysql.server && /var/log/mariadb'
    exit -1
fi
bin=$(dirname ${BASH_SOURCE-$0})
bin=$(cd $bin ; pwd)
cd $bin
file_mysql=mysql-8.0.31-linux-glibc2.12-x86_64.tar.xz
path_mysql=`echo $file_mysql | awk -F '.tar' '{print $1}'`
path_mysql_full="$(cd $1 ; pwd)/$path_mysql"
export PATH=$PATH:tmp/mysql-8.0.31-linux-glibc2.12-x86_64/bin
msg_info="[INFO]"
# check if exists group:mysql
echo '@Step1 -> groupadd mysql'
if_exists_group_mysql=$(cat /etc/group| grep mysql)
if [ -n "${if_exists_group_mysql}" ] 
then
    echo ${msg_info}' group:mysql exists.'
else
    groupadd mysql
    echo ${msg_info}' groupadd mysql ok.'
fi
if_exists_user_mysql=$(cat /etc/shadow | grep mysql)
if [ -n "${if_exists_user_mysql}" ]
then
    echo ${msg_info}‘ group:mysql exists’
else
    useradd -r -g mysql -s /bin/false mysql
    echo ${msg_info} ' useradd -r -g mysql -s /bin/false mysql ok'
fi
if [ -f $file_mysql ]
then
    echo "exist "$file_mysql
else
    wget "https://downloads.mysql.com/archives/get/p/23/file/$file_mysql"
fi
tar -xvf $file_mysql -C $1/
cd $1/$path_mysql 
mkdir -p mysql-files 
chown mysql:mysql mysql-files
chmod 750 mysql-files
yum install -y libaio
./bin/mysqld --initialize --user=mysql
./bin/mysql_ssl_rsa_setup 
mkdir -p /var/log/mariadb
touch /var/log/mariadb/mariadb.log
chown -R mysql:mysql /var/log/mariadb
./bin/mysqld_safe --user=mysql &   
#sed -i "s/basedir=\$/basedir=$(pwd)/g" support-files/mysql.server 
#sed -i "s/datadir=\$/basedir=$(pwd)\/data/g" support-files/mysql.server
cp support-files/mysql.server /etc/init.d/mysql.server
echo "export PATH=\$PATH:$path_mysql_full/bin" >> /etc/profile
source /etc/profile
echo 'Successfully!!!'
echo 'you can execute  [/etc/init.d/mysql.server start] to start mysql'
exit 0



  • 推荐执行的命令:./scripts.sh '/usr/local/mysql'
  • 整个安装脚本是上一篇文章的完整命令整合的
  • 脚本执行完毕之后,切记屏幕上会出现初始的root密码,不要看漏了,不然登录不上会有点麻烦,然后根据提示执行:/etc/init.d/mysql.server start  即可启动mysql。
  • 如果启动有问题,可以根据脚本去修改 /etc/init.d/mysql.server




相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
Shell Linux
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
97 32
|
1月前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
175 42
|
1月前
|
存储 Linux 网络安全
linux应急响应检查脚本
通过这个脚本,可以快速收集系统的关键信息,有助于在发生问题时进行及时的应急响应和分析。
102 34
|
2月前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
276 16
|
3月前
|
关系型数据库 MySQL 数据库
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
|
3月前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
144 14
|
2月前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
152 7
|
3月前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
166 8
|
3月前
|
安全 关系型数据库 MySQL
Windows Server 安装 MySQL 8.0 详细指南
安装 MySQL 需要谨慎,特别注意安全配置和权限管理。根据实际业务需求调整配置,确保数据库的性能和安全。
375 9