Home  >  Article  >  Computer Tutorials  >  Shell script to automate the installation of MySQL database

Shell script to automate the installation of MySQL database

PHPz
PHPzforward
2024-02-19 22:00:04978browse

This article mainly uses the Shell scripting language to automatically install the MySQL database, thereby improving our work efficiency.

Shell script to automate the installation of MySQL database

大致思路及步骤如下:

第一步:首先,自定义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数据目录,并将目录下的所有文件和子目录的所有者和所属组设置为:

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 <<EOF
[mysqld]
character-set-server=utf8
server-id = 1
lower_case_table_names=1
basedir=${binDir}
datadir=${dataDir}
user=mysql
symbolic-links=0
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

[client]
default-character-set=utf8

[mysqld_safe]
default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci
EOF

[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 <<EOF
SET PASSWORD = PASSWORD('${mysqlPassword}');
ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
create database hive;
create database ranger;
create user 'hive' identified by '1q!2w@3e#';
grant all on *.* to hive@"%" identified by "1q!2w@3e#";
grant all on *.* to root@'%' identified by'1q!2w@3e#';
UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERE User='root';
FLUSH PRIVILEGES;
EOF

echo "[INFO] 安装完成"
exit 0
  • ${binDir}/bin/mysql -uroot :在命令行中执行<code>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安装完成。

The above is the detailed content of Shell script to automate the installation of MySQL database. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:mryunwei.com. If there is any infringement, please contact admin@php.cn delete