0

0

自动化安装MySQL数据库的Shell脚本

PHPz

PHPz

发布时间:2024-02-19 22:00:04

|

1172人浏览过

|

来源于每日运维

转载

本文主要通过shell脚本语言的方式自动化安装mysql数据库,从而提高我们的工作效率。

自动化安装MySQL数据库的Shell脚本

大致思路及步骤如下:

第一步:首先,自定义MySQL数据库的安装目录、MySQL数据存储目录和MySQL数据库超级用户的密码变量。

#!/bin/bash
binDir='/usr/local/mysql' # MySQL 数据库的安装目录
dataDir='/bigdata/mysql/mysqldata'# MySQL 数据存储目录
mysqlPassword='1q!2w@3e#' # MySQL 数据库超级用户的密码

第二步:获取当前脚本所在的目录,并将该目录赋值给变量BASE

然后,使用cd命令切换到这个目录。通常用于确保脚本在执行时位于正确的工作目录。

BASE=$(cd `dirname $0` && pwd)
cd $BASE

第三步:检查操作系统的内核版本是否为el7,如果不是,则输出错误信息并退出安装。

release=$(uname -r |awk -F'.' '{print $4}')
if [ "X${release}" != 'Xel7' ];then
echo "[ERROR] 操作系统版本: ${release}, 非el7, 退出安装"
exit 1
fi
  • release=$(uname -r |awk -F'.' '{print $4}'):获取当前操作系统的内核版本,并提取出版本号中的第四个字段,然后将其赋值给变量release
  • 接着通过条件判断语句,使用ifthen来检查变量release是否等于el7。如果不等于el7,则输出错误信息并退出安装。
  • [ "X${release}" != 'Xel7' ]:是一个条件判断,X 是为了防止变量为空时出现错误。如果条件成立,则执行echo输出错误信息,然后使用exit 1退出安装。

第四步:检查${binDir}${dataDir}两个变量中是否包含/mysql关键字。如果这两个变量中没有包含/mysql,则会输出相应的错误信息并退出脚本。

keyword='/mysql'
if ! echo "${binDir}" |grep ${keyword} &>/dev/null; then
echo "[ERROR] ${binDir}配置错误, 没有包含${keyword}"
exit 1
fi

if ! echo "${dataDir}" |grep ${keyword} &>/dev/null; then
echo "[ERROR] ${dataDir}配置错误, 没有包含${keyword}"
exit 1
fi

第五步:停止MySQL进程并清理指定目录。

echo "[INFO] 停止mysql进程, 并清理目录: ${binDir}, ${dataDir}..."
service mysql stop &>/dev/null
test -d ${binDir} && rm -fr ${binDir}
test -d ${dataDir} && rm -fr ${dataDir}
  • echo "[INFO] 停止mysql进程, 并清理目录: ${binDir}, ${dataDir}...":使用echo命令打印一条信息,其中${binDir}${dataDir}是变量,会被替换为实际的目录路径。
  • service mysql stop &>/dev/null:使用service命令来停止MySQL服务。&>/dev/null部分是将命令的输出重定向到/dev/null,即丢弃输出,这样将不会在终端上显示任何信息。
  • test -d ${binDir} && rm -fr ${binDir}:使用test -d检查${binDir}是否是一个目录,如果是,则执行rm -fr ${binDir}来递归地删除${binDir}目录及其内容。
  • test -d ${dataDir} && rm -fr ${dataDir}:使用test -d检查${dataDir}是否是一个目录,如果是,则执行rm -fr ${dataDir}来递归地删除${dataDir}目录及其内容。

第六步:在命令行中输出日志信息:[INFO] 开始解压mysql安装包, 请等待…,然后执行解压缩命令tar zxf mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz,接着将解压后的文件夹移动到自定义变量${binDir}的目录中。

echo "[INFO] 开始解压mysql安装包, 请等待..."
tar zxf mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz && mv mysql-5.7.25-linux-glibc2.12-x86_64 ${binDir}

第七步:创建mysql的组和用户。

echo "[INFO] 创建mysql组与用户..."
groupadd mysql 2>/dev/null
useradd -r -g mysql mysql 2>/dev/null
  • groupadd mysql 2>/dev/null:使用groupadd命令创建一个名为mysql的组。2>/dev/null的作用是将错误输出重定向到/dev/null,这样如果组已经存在,就不会显示错误信息。
  • useradd -r -g mysql mysql 2>/dev/null:使用useradd命令创建一个名为mysql的用户,并将其加入到mysql组中。
  • -r:表示创建一个系统用户,-g mysql:表示将用户添加到mysql组。同样,2>/dev/null的作用是将错误输出重定向到/dev/null,以防止显示错误信息。

第八步:创建MySQL数据目录,并将目录下的所有文件和子目录的所有者和所属组设置为:

PHP简约自动发卡平台个人版
PHP简约自动发卡平台个人版

PHP自动发卡平台个人版是采用php+mysql进行开发的自动发卡支付平台。服务器环境:PHP5.2以上版本mysql5.1 或以上版本安装说明:安装 http://你的域名/install.php 进行安装,后台路径http://你的域名/admin 后台账号:admin 后台密码:yc88.net需要修改用户名,可以进入数据库进行修改faka_users把admin改成其他支持改成中文

下载
echo "[INFO] 创建mysql数据目录..."
mkdir -p${dataDir} && chown -R mysql:mysql ${dataDir}
chown -R mysql:mysql ${binDir}
  • echo "[INFO] 创建mysql数据目录...":输出一条信息,提示用户正在创建MySQL数据目录。
  • mkdir -p ${dataDir} && chown -R mysql:mysql ${dataDir}:首先,mkdir -p ${dataDir}用于创建目录${dataDir}-p:表示如果目录不存在,则进行创建。
  • 接着,&&是逻辑与操作符,只有在前一个命令成功执行后才执行后一个命令。所以,如果目录创建成功,才会执行chown -R mysql:mysql ${dataDir}命令将以递归的方式(包括子目录和文件)将${dataDir}目录下的所有文件和子目录的所有者和所属组设置为mysql:mysql

第九步:创建MySQL的配置文件/etc/my.cnf。该配置文件包含了MySQL服务器mysqld和客户端client的配置信息。

echo "[INFO] 创建mysql配置文件:/etc/my.cnf ..."
cat >/etc/my.cnf <

[mysqld]MySQL服务器的配置部分,具体配置参数选项如下:

  • character-set-server=utf8:服务器的字符集为 UTF-8
  • server-id = 1:服务器的唯一ID为 1
  • lower_case_table_names=1:表名大小写不敏感
  • basedir=${binDir}:MySQL 的安装目录
  • datadir=${dataDir}:MySQL 的数据目录
  • user=mysql:MySQL 服务的运行用户
  • symbolic-links=0:禁用符号链接
  • federated:启用 Federated 存储引擎
  • sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION:设置 SQL 模式

[client]MySQL客户端的配置部分,具体配置参数选项如下:

  • default-character-set=utf8:客户端的默认字符集为 UTF-8

[mysqld_safe]MySQL安全模式的配置部分,具体配置参数选项如下:

  • default-storage-engine=INNODB:默认的存储引擎为InnoDB
  • character-set-server=utf8:服务器的字符集为 UTF-8
  • collation-server=utf8_general_ci:服务器的排序规则为 utf8_general_ci

第十步:初始化MySQL数据库

# 初始化mysql
echo "[INFO] 初始化mysql..."
${binDir}/bin/mysqld --defaults-file=/etc/my.cnf --basedir=${binDir} --datadir=${dataDir} --user=mysql --initialize-insecure

该命令会执行mysqld可执行文件,并使用指定的配置文件、安装目录、数据目录和用户来初始化MySQL数据库。

  • --initialize-insecure:以不安全的方式初始化数据库,会创建一个空密码的root用户。

第十一步:添加开机启动

echo "[INFO] 添加mysql服务, 以及开机启动..."
ln -sf ${binDir}/bin/mysql /usr/local/bin/mysql
ln -sf ${binDir}/support-files/mysql.server /etc/init.d/mysql
/usr/bin/systemctl enable mysql
  • ln -sf ${binDir}/bin/mysql /usr/local/bin/mysql:创建一个符号链接,将${binDir}/bin/mysql链接到/usr/local/bin/mysql-s:表示创建一个符号链接,-f:表示如果/usr/local/bin/mysql已经存在,则先删除。${binDir}/bin/mysql是源文件,/usr/local/bin/mysql是链接文件。
  • ln -sf ${binDir}/support-files/mysql.server /etc/init.d/mysql:创建一个符号链接,将${binDir}/support-files/mysql.server链接到/etc/init.d/mysql-s选项表示创建一个符号链接,-f选项表示如果/etc/init.d/mysql已经存在,则先删除。${binDir}/support-files/mysql.server是源文件,/etc/init.d/mysql是链接文件。
  • /usr/bin/systemctl enable mysql:使用systemctl命令启用mysql服务,使其在系统启动时自启动。

第十二步:启动 MySQL 服务

echo "[INFO] 启动mysql服务..."
service mysql start
if [ $? -ne 0 ];then
echo "[ERROR] mysql启动失败, 查看mysql日志: ${dataDir}下的.err文件"
exit 2
fi
  • echo "[INFO] 启动mysql服务...":用于在控制台输出一条信息,提示用户正在启动MySQL服务。
  • service mysql start:启动MySQL服务。
  • if [ $? -ne 0 ];then:条件语句,用于检查上一条命令的执行结果。$?:是一个特殊变量,用于获取上一个命令的退出状态。如果上一个命令执行成功,其退出状态为0,否则为非0
  • echo "[ERROR] mysql启动失败, 查看mysql日志: ${dataDir}下的.err文件"MySQL服务启动失败时,将输出一条错误信息,并提示查看MySQL日志文件。
  • exit 2:如果MySQL服务启动失败,将以退出码2结束执行,表示出现了错误。

第十三步:在 MySQL 数据库中创建用户、数据库和授予权限

echo "[INFO] 修改mysql用户密码..."
${binDir}/bin/mysql -uroot <
  • ${binDir}/bin/mysql -uroot :在命令行中执行MySQL客户端并使用root用户登录的命令。
  • SET PASSWORD = PASSWORD('${mysqlPassword}');:设置MySQL用户密码。
  • ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;:将root用户的密码过期策略设置为永不过期。
  • create database hive;:创建名为hive的数据库。
  • create database ranger;:创建名为ranger的数据库。
  • create user 'hive' identified by '1q!2w@3e#';:创建一个名为hive的用户,并设置其密码为:1q!2w@3e#
  • grant all on *.* to hive@"%" identified by "1q!2w@3e#";:授予用户hive对所有数据库的所有权限,并使用指定的密码进行身份验证。
  • grant all on *.* to root@'%' identified by'1q!2w@3e#';:授予root用户对所有数据库的所有权限,并使用指定的密码进行身份验证。
  • UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERE User='root';:更新MySQL用户表中root用户的权限,将Grant_privSuper_priv设置为:Y,表示拥有所有权限。
  • FLUSH PRIVILEGES;:刷新MySQL的权限,使其配置生效。

最后,代码中的 echo 命令用于输出一些提示信息,提示用户MySQL安装完成。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

683

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1096

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

358

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

697

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

418

2024.04.29

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 805人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号