本人经过多次尝试,简单完成了自动部署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. cocos2dx截整屏、截部分屏

    我的环境是cocos2dx 2.x的版本 [CCRenderTexture] CCRenderTexture这个动态纹理类,顾名思义就是可以动态创建纹理图片. 屏幕截图主要步骤: > 开始截图: ...

  2. mybatis入门-框架原理

    mybatis是什么 在说mybatis原理之前,我们有必要知道,mybatis到底是个什么东西.mybatis是一个持久层的框架.是一个不完全的ORM框架.因为它需要由程序员自己去写sql语句.但是 ...

  3. python书籍推荐

    python书籍推荐列表: 技巧:关于如何在windows平台上行获取目录下的文件名称.(我的python书籍的位置E:\Python\Python_book) D:\>e: E:\>cd ...

  4. Java丨博客系统

    后台界面: 前台界面: 这是一个由我带着刚入门的几位实习生做的一个博客系统,希望给java入门的学习者一个例子,这个系统还需要完善,主体功能是实现了,还差一些细节,如果需要源码的话可以在下方给我留言! ...

  5. 快速排序的C语言实现

    #include <stdio.h> int qSort(int a[],int i,int j) { int h = i; int r = j; int x = a[h]; int f ...

  6. 征服恐惧!用 Vim 写 iOS App

    我们都知道 Vim 和 Emacs 都是文本编辑器中的上古神器,你也许用 ctags,cscopes 配合 Vim 完成过大型 C 或者 C++ 的开发,你也许配合过其他插件,完成过 JavaScri ...

  7. [Hadoop] - Hadoop3.0.x编译

    这里仅介绍一种Hadoop3.0.x版本的源码编译方式 编译过程 1. 下载源码 2. 安装依赖环境 3. 源码编译 ========================================= ...

  8. Java 内部类详解

    什么 定义在一个类内部的类,称为内部类(累不累),如下: public class A { private int c = 1; public class C { public void test() ...

  9. mybatis系列笔记(4)---输入输出映射

    输入输出映射 通过parameterType制定输入参数类型 类型可以是简单类型(int String)也可以是POJO本身 或者包装类 1输入映射 关于输入简单类型和pojo本身的我就不写了,因为比 ...

  10. js基础---cookie存储

    一.Cookie是什么Cookie是一种客户端(浏览器)把用户信息以文件形式存储到本地硬盘的技术,说白了就是一种浏览器技术 二.Cookie的作用Cookie的作用很单一,就是存储客户数据.(存储数据 ...