本人经过多次尝试,简单完成了自动部署Nginx和nfs脚本,并且能够自动部署web反向代理集群,下面详细的阐述一下本人的思路。(以下脚本本人处于初学阶段,写的并不是很完善,所以需要后期进行整理和修正,请高手能够多多指教。)

本脚本需要注意的是:

1、这是针对centOS6.8,32位操作系统写的脚本文件,如果想在cenOS7中运行,就需要有些改动

2、这个脚本需要先安装代理服务器部分,再安装反向代理服务器,因为涉及到共享文件夹挂载的问题,所以需要有先后顺序;

3、今后本人会对此脚本进行更新和完善,希望朋友们来相互交流。

#!/bin/bash
login=0
server_leader='192.168.1.104' #设置代理服务器IP地址;
server_web1='192.168.1.105:80 weight=3' #设置第一台反向代理服务器地址并设置权重参数;
server_web2='192.168.1.106:80' #设置第二台反向代理服务器地址;
server_web3='192.168.1.107:80' #设置第三台反向代理服务器地址;
server_nfs='192.168.1.0' #设置nfs共享配置文件的网络地址; function install_nginx(){ #命名安装nginx的函数;
yum -y install epel-release; #安装epel扩展源(因为安装Nginx服务需要epel扩展源);
yum -y install nginx ; #安装Nginx服务;
result=`echo $?`; #将安装是否成功的结果返回给result变量;
if (( $result == 0 )); #判断返回结果是不是成功
then
echo 'Congratulations!!';
echo 'Now will be starting the service,please wait...';
chkconfig nginx on; #将nginx设置为开机启动
service nginx start; #安装完成后启动Nginx服务;
start_result=`echo $?`; #将启动结果存入变量start_result;
if (( $start_result == 0 )); #判断启动结果是否成功;
then
cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak #将nginx.conf配置文件备份;
echo 'The service is started successful';
echo 'Install nginx successful,the system will be exit,ByeBye!!';
else
echo 'Please find some error to reinstall.ByeBye!!';
break;
fi
else
echo 'Please find some error to reinstall.ByeBye!!';
fi
}
function install_nfs(){ #创建安装nfs服务的函数;
yum -y install rpcbind nfs-utils #安装rpcbind和nfs-utils服务;
result=`echo $?` #将安装结果放入result变量;
if (( $result == 0 )); #判断安装结果是否成功;
then
echo '******************Congratulations!!************************';
echo '******Now will be starting the service,please wait...******';
chkconfig rpcbind on; #将rpcbind设置为开机启动
chkconfig nfs on; #将nfs设置为开机启动
service rpcbind restart; #启动rpcbind服务;
service nfs restart; #启动nfs服务;
start_result=`echo $?`; #将启动结果存入start_result;
if (( $start_result == 0 )); #判断启动结果是否成功;
then
echo '*************The service is started successful*************';
echo '**Install nfs successful,the system will be exit,ByeBye!!**';
else
echo '*******Please find some error to reinstall.ByeBye!!*******';
break;
fi
else
echo '************Please find some error to reinstall.**********';
fi
} function set_nginx(){ #创建设置nginx服务函数; sed -ri "s/(http \{)/http \{ \n\ upstream Mysite\{\n server $server_web1;\n server $server_web2;\n server $server_web3;\n \}\n server \{\n server_name $server_leader;\n listen 80;\n location\ \/\{\n proxy_pass\ http\:\/\/Mysite;\n \}\n \}/" /etc/nginx/nginx.conf
#修改配置文件/etc/nginx/nginx.conf配置文件
} function set_nfs(){ #创建设置nfs的函数;
mkdir /share #创建共享目录share;
echo 'test web server!!' > /share/index.html #往share目录中写入文件index.html;
echo "/share $server_nfs/24(rw,sync,fsid=0)" > /etc/exports #创建nfs共享配置文件并将配置写入文件;
chmod o=rwx /share #给共享配置文件添加读写执行权限;
/etc/init.d/rpcbind restart #重启rpcbind服务;
/etc/init.d/nfs restart #重启nfs服务,使配置文件生效;
}
function set_web(){ #创建设置反向代理服务器函数;
mount -t nfs $server_leader:/share/ /usr/share/nginx/html/ #将共享目录挂载到反向代理服务器的主目录中;
/etc/init.d/nginx restart #重启nginx服务使配置生效;
}
while (( $login == 0 ))
do
echo '+===================================================+'
echo '| Welcome to my Nginx auto install system!!! |'
echo '| 1.install ordinary web server |'
echo '| 2.install proxy web server |'
echo '| 3.exit |'
echo '+===================================================+'
read -p 'Please chose your number:' chose #可以选择1:安装反向代理服务器(也就是普通的web服务器);2:安装代理服务器;3:退出系统
if [ ! $chose ]
then
continue
fi
if (( $chose == 1 ))
then
echo 'Your choice is number 1,the ordinary web server will be install,Are you sure?'
read -p 'y/n:' pd
if [ "$pd" == 'y' ];
then
echo $pd
install_nginx;
set_web;
fi
if [ "$pd" == 'n' ];
then
continue;
fi
elif (( $chose == 2 ))
then
echo 'Your choice is number 2,the proxy web server will be install,Are you sure?'
read -p 'y/n:' pd2
if [ "$sp2" = 'y' ];
echo $sp2
then
echo $pd2
install_nginx;
install_nfs;
set_nginx;
set_nfs;
fi
if [ "$pd2" = 'n' ]
then
continue
fi
elif (( $chose == 3 ))
then
echo 'Thank you use my system,ByeBye.'
break
else
continue
fi
done
exit

  

自动部署Nginx和nfs并架设Nginx集群脚本的更多相关文章

  1. Linux之nginx反向代理+三台web+nfs共享存储实现集群配置

    作业四:nginx反向代理+三台web+nfs共享存储实现集群配置 在各个web服务器上挂载nfs [root@localhost nginx]# mount -t nfs 192.168.152.1 ...

  2. Keepalived+Nginx+Tomcat 实现高可用Web集群

    https://www.jianshu.com/p/bc34f9101c5e Keepalived+Nginx+Tomcat 实现高可用Web集群 0.3912018.01.08 20:28:59字数 ...

  3. 基于nginx的tomcat负载均衡和集群

    要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了. 你可以自己写tomcat的扩展来保存SESSI ...

  4. Nginx --Windows下和Linux下搭建集群小记

    nginx: Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器 特点: 反向代理 负载均衡 动静分离... 反向代理 : 先来了解正向代理:需要我们用户 ...

  5. NGINX实现咏南跨平台中间件集群

    NGINX实现咏南跨平台中间件集群 首先要开启咏南LINUX中间件. 1)编辑usr/local/nginx/conf/nginx.conf #user  nobody;worker_processe ...

  6. lvs+keepalived部署k8s v1.16.4高可用集群

    一.部署环境 1.1 主机列表 主机名 Centos版本 ip docker version flannel version Keepalived version 主机配置 备注 lvs-keepal ...

  7. Centos7.6部署k8s v1.16.4高可用集群(主备模式)

    一.部署环境 主机列表: 主机名 Centos版本 ip docker version flannel version Keepalived version 主机配置 备注 master01 7.6. ...

  8. [CoreOS 转载]CoreOS实践指南(二):架设CoreOS集群

    转载:http://www.csdn.net/article/2015-01-04/2823399 摘要:CoreOS是一个采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件 ...

  9. Ambari安装之部署3个节点的HA分布式集群

    前期博客 Ambari安装之部署单节点集群 其实,按照这个步骤是一样的.只是按照好3个节点后,再做下HA即可. 部署3个节点的HA分布式集群 (1)添加机器 和添加服务的操作类似,如下图 之后的添加a ...

随机推荐

  1. JAVA构造函数的继承

    1.子类中无参构造函数,可直接继承父类中无参构造函数,前提是所有变量均为public 如下:父类Student中有空构造函数Student(),子类Pupil中有空构造函数Pupil(),后者会继承前 ...

  2. 获取SQL中某一列的类型及精度

    SELECT @type=t.name, @prec=c.prec FROM sysobjects o        JOIN syscolumns c on o.id=c.id        JOI ...

  3. C#表达式和语句

    表达式由操作数 (operand) 和运算符 (operator) 构成.表达式的运算符指示对操作数适用什么样的运算.运算符的示例包括+.-.*./ 和 new.操作数的示例包括文本.字段.局部变量和 ...

  4. 【问题解决】使用自定义控件时,vs停止工作

    问题表现:向页面中添加自定义控件时,vs卡住了,随便点击一下,然后窗口未响应,然后用资源管理器看到内存使用在飙升,监视进程会发现就是vs的进程出现了异常 问题的解决:菜鸟D在网上搜了一下,发现一个奇葩 ...

  5. 用canvas的arc绘制时钟

    在页面上加入canvas标签: <body> <canvas id="c1" width="600px" height="600px ...

  6. STM32F4时钟配置分析

    //学习STM32F4的过程中关于时钟上面讲的比较好 特地转发与大家分享 STM32F4时钟设置分析 原文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明. 环 ...

  7. ubuntu14.04 + OpenCV2.4.9 配置方法

    1.  安装openCV 所需依赖库或软件: sudo apt-get install build-essential cmake libgtk2.0-dev pkg-config python-de ...

  8. 粗谈shell脚本风格

    注意:此风格并非官方版本,为个人在编写和维护脚本程序时总结出来的民间版本.0. 开头:除去开头的#!/bin/bash,最前面的就是脚本描述注释了,视个人喜好而定,例如: ############## ...

  9. java与javac的区别

    1.前提:java分为两部分 一个是编译(javac命令),一个是运行(java命令) 2.java与javac的区别 javac负责的是编译,将.java文件编译成.class文件,当执行javac ...

  10. 大型ERP系统在线体验

    ERP简单说明: AIO7构建了基于SOA三层架构的管理软件平台.客户通过网络即可得到ERP服务,不用安装服务器.不用建立数据中心.不用安装软件.无需专业IT支持,任何上网设备就可以使用高性能.功能集 ...