shell脚本多实例部署MySQL

多实例部署MySQL

//创建一个目录存放脚本
[root@master ~]# mkdir /script
[root@master packages]# pwd
/script/packages
[root@master packages]# ls
mysql-5.7.34-linux-glibc2.12-x86_64.tar.gz

//编写脚本
[root@master script]# cat mysql.sh
#!/bin/bash
route=/usr/local
data=/opt/data
read -p "请输入要部署的实例个数:" deploy
if [ -z $deploy ];then
	deploy=1
fi

echo $deploy | grep -E '^[0-9]+$' &> /dev/null
if [ $? -ne 0 ];then
	$deploy=1
fi

read -sp "请输入要设置的数据库密码: " passwd
if [ -z $passwd ];then
	passwd=123
fi

function first(){
    if [ ! -d $data ];then
        mkdir -p $data
    fi
    chown -R mysql.mysql $data
    look=$(ls $data | wc -l)
    if [ $look -eq 0 ];then
        $route/mysql/bin/mysqld --initialize-insecure --user mysql --datadir=$data
    fi
    
    if [ ! -d $route/mysql ];then
        cat > /etc/my.cnf << EOF
[mysqld]
basedir = $route/mysql
datadir = $data
socket = /tmp/mysql.sock
port = 3306
pid-file = $data/mysql.pid
skip-name-resolve
user = mysql
EOF
    fi
    sed -ri "s#^(basedir=).*#\1$route/mysql#g" $route/mysql/support-files/mysql.server
    sed -ri "s#^(datadir)=.*#\1$data#g" $route/mysql/support-files/mysql.server

    cat > /usr/lib/systemd/system/mysqld.service <<EOF
[Unit]
Description=mysql server daemon
After=network.target

[Service]
Type=forking
ExecStart=$route/mysql/support-files/mysql.server start
ExecStop=$route/mysql/support-files/mysql.server stop
ExecReload=/bin/kill -HUP \$MAINPID

[Install]
WantedBy=multi-user.target
EOF
    systemctl daemon-reload
    systemctl enable --now mysqld
    sleep 3
    $route/mysql/bin/mysql -uroot -e "set password=password('$passwd')"
}

function many(){
    port=3305
    cat > /etc/my.cnf << EOF
[mysqld_multi]
mysqld = $route/mysql/bin/mysqld_safe
mysqladmin = $route/mysql/bin/mysqladmin

EOF
    for i in $(seq $deploy);do
	let port++
	if [ ! -d $data/$port ];then
            mkdir -p $data/$port
	fi
	chown -R mysql.mysql $data/port
	look=$(ls $data/$port | wc -l)
	if [ $look -eq 0 ];then
            $route/mysql/bin/mysqld --initialize-insecure --user mysql --datadir=$data/$port
	fi
        cat >> /etc/my.cnf <<EOF
[mysqld$port]
datadir = $data/$port
port = $port
socket = /tmp/mysql$port.sock
pid-file = $data/$port/mysql.pid
log-error=/var/log/$port.log

EOF
        $route/mysql/bin/mysqld_multi start $port
	sleep 3
	$route/mysql/bin/mysql -uroot -P$port -h127.0.0.1 -e "set password=password('$passwd')"
    done
    cat > /usr/lib/systemd/system/mysqld.service <<EOF
[Unit]
Description=mysql server daemon
After=network.target

[Service]
Type=forking
ExecStart=$route/mysql/support-files/mysqld_multi.server start
ExecStop=$route/mysql/support-files/mysqld_multi.server stop
ExecReload=/bin/kill -HUP \$MAINPID

[Install]
WantedBy=multi-user.target
EOF
   systemctl daemon-reload
   systemctl enable mysqld
}

yum -y install ncurses-compat-libs perl libncurses*

id mysql &>/dev/null
if [ $? -ne 0 ];then
    useradd -r -M -s /sbin/nologin mysql
fi

if [ ! -d $route/mysql-5.7.32-linux-glibc2.12-x86_64 ] && [ ! -d $route/mysql ];then
	tar xf packages/mysql-5.7.32-linux-glibc2.12-x86_64.tar.gz -C $route
        ln -s $route/mysql-5.7.32-linux-glibc2.12-x86_64/ $route/mysql
fi

chown -R mysql.mysql $route/mysql*
echo "export PATH=$route/mysql/bin:\$PATH" > /etc/profile.d/mysql.sh 
. /etc/profile.d/mysql.sh
if [ $deploy -eq 1 ];then
	first
else
	many
fi
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值