Ngixn负载+Keepalived高可用Shell脚本

本文介绍了一个使用Vim进行自动化配置Keepalived和Nginx的脚本,详细展示了如何通过脚本实现Keepalived的安装、配置文件编辑、公钥交换以及Nginx的编译安装过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vim nginx-keepalived.sh
#/bin/bash
read -ep "请输入keepalived所在的本地IP:" IP
read -ep "请输入另一台keepalived所在的本地IP:" IP2
read -ep "请输入你创建的keepalived的VIP:" net
read -ep "请输入ngixn负载的IP:" fu
read -ep "请输入ngixn负载的另一条IP:" fu2
read -ep "是否终止(y),默认不终止" yn
if [ $yn == y ];then
 exit
fi
yum -y install keepalived
sed -i '/notification_email {/,/smtp_connect_timeout 30/d' /etc/keepalived/keepalived.conf
sed -i '/vrrp_skip_check_adv_addr/,/vrrp_gna_interval 0/d' /etc/keepalived/keepalived.conf
sed -i 's/eth0/ens33/' /etc/keepalived/keepalived.conf
sed -i '/persistence_timeout 50/d' /etc/keepalived/keepalived.conf
sed -i '/real_server/,$d' /etc/keepalived/keepalived.conf
sed -i '/192.168.200.16/,/192.168.200.17/d' /etc/keepalived/keepalived.conf
sed -i "s/192.168.200.18/$net/" /etc/keepalived/keepalived.conf
sed -i "s/192.168.200.100 443/$net 80/" /etc/keepalived/keepalived.conf
chmod +x /etc/keepalived/bb.sh
shu=`cat /etc/keepalived/keepalived.conf|grep real_server|wc -l`
if [ $shu -ne 1 ];then
echo "    real_server $IP 80{
        weight 1
        notify_down /etc/keepalived/bb.sh
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
            connect_port 80
        }   
    }   
}
" >>/etc/keepalived/keepalived.conf
fi
echo '#!/bin/bash
pkill -9 keepalived'>/etc/keepalived/bb.sh
yum -y install expect
if [ -f /root/.ssh/id_rsa ]||[ -f id_rsa.pub ];then #判断是否有公密钥
  continue
else    #否则生产公密钥
/usr/bin/expect <<EOF  
spawn ssh-keygen -t rsa
expect ":" {send "\n;"}
expect ":" {send "\n;"}
expect ":" {send "\n;"}
expect eof
EOF
fi
/usr/bin/expect <<EOF
spawn ssh-copy-id root@$IP2
expect "yes/no" {send "yes\n;exp_continue"}
expect "password" {send "123456\n;"}
expect eof
EOF
ssh root@$IP2 'yum -y install keepalived'
scp /etc/keepalived/keepalived.conf $IP2:/etc/keepalived/keepalived.conf
scp /etc/keepalived/bb.sh $IP2:/etc/keepalived/bb.sh
/usr/bin/expect<<EOF
spawn ssh root@$IP2  
expect "~" {send "sed -i 's/$IP/$IP2/' /etc/keepalived/keepalived.conf\n"}
expect "~" {send "sed -i 's/priority 100/priority 99/' /etc/keepalived/keepalived.conf\n"}
expect "~" {send "sed -i 's/MASTER/BACKUP/' /etc/keepalived/keepalived.conf\n"}
expect "~" {send "exit\n"}
expect eof
EOF
wget http://nginx.org/download/nginx-1.16.1.tar.gz
yum -y install gcc gcc-c++ zlib-devel pcre-devel
tar zxf nginx-1.16.1.tar.gz
cd nginx-1.16.1 && ./configure && make && make install
shulian=`cat /usr/local/nginx/conf/nginx.conf|grep 'server 192.168.11.135:8081;'|wc -l`
if [ $shulian -ne 1 ];then #判断是否有该配置
sed -i  '/#gzip  on;/aupstream wg{' /usr/local/nginx/conf/nginx.conf   #在gzip  on;下一行追加upstream wg{
sed -i  "/upstream wg{/aserver $fu:8080;" /usr/local/nginx/conf/nginx.conf   #在upstream wg{下一行追加server 192.168.11.135:8080;
sed -i  "/server $fu:8080;/aserver $fu2:8081;" /usr/local/nginx/conf/nginx.conf  #在server 192.168.11.135:8080;下一行追加server 192.168.11.135:8081;
sed -i  "/server $fu2:8081/a\}" /usr/local/nginx/conf/nginx.conf  #在server 192.168.11.135:8081;下一行追加}
sed -i  's/index.htm;$/index.jsp;/' /usr/local/nginx/conf/nginx.conf  #把以index.htm;结尾换成index.jsp;
sed -i  '/404.html;/alocation ~ \\.jsp$ {' /usr/local/nginx/conf/nginx.conf  #在404.html;下一行追加location ~ \.jsp$ {
sed -i  '/location ~ \\.jsp$ {/aproxy_pass   http://wg;' /usr/local/nginx/conf/nginx.conf #在location ~ \.jsp$ {下一行追加proxy_pass   http://wg;
sed -i  '/proxy_pass   http:\/\/wg;/a\}' /usr/local/nginx/conf/nginx.conf  #在proxy_pass   http://wg;下一行追加}
fi
/usr/local/nginx/sbin/nginx
systemctl restart keepalived
ssh root@$IP2 'wget http://nginx.org/download/nginx-1.16.1.tar.gz;yum -y install gcc gcc-c++ zlib-devel pcre-devel;tar zxf nginx-1.16.1.tar.gz;cd nginx-1.16.1 && ./configure && make && make install'
scp /usr/local/nginx/conf/nginx.conf $IP2:/usr/local/nginx/conf/nginx.conf
ssh root@$IP2 '/usr/local/nginx/sbin/nginx && systemctl restart keepalived'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值