自动部署Nginx和nfs并架设Nginx集群脚本
本人经过多次尝试,简单完成了自动部署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集群脚本的更多相关文章
- Linux之nginx反向代理+三台web+nfs共享存储实现集群配置
作业四:nginx反向代理+三台web+nfs共享存储实现集群配置 在各个web服务器上挂载nfs [root@localhost nginx]# mount -t nfs 192.168.152.1 ...
- Keepalived+Nginx+Tomcat 实现高可用Web集群
https://www.jianshu.com/p/bc34f9101c5e Keepalived+Nginx+Tomcat 实现高可用Web集群 0.3912018.01.08 20:28:59字数 ...
- 基于nginx的tomcat负载均衡和集群
要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了. 你可以自己写tomcat的扩展来保存SESSI ...
- Nginx --Windows下和Linux下搭建集群小记
nginx: Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器 特点: 反向代理 负载均衡 动静分离... 反向代理 : 先来了解正向代理:需要我们用户 ...
- NGINX实现咏南跨平台中间件集群
NGINX实现咏南跨平台中间件集群 首先要开启咏南LINUX中间件. 1)编辑usr/local/nginx/conf/nginx.conf #user nobody;worker_processe ...
- lvs+keepalived部署k8s v1.16.4高可用集群
一.部署环境 1.1 主机列表 主机名 Centos版本 ip docker version flannel version Keepalived version 主机配置 备注 lvs-keepal ...
- Centos7.6部署k8s v1.16.4高可用集群(主备模式)
一.部署环境 主机列表: 主机名 Centos版本 ip docker version flannel version Keepalived version 主机配置 备注 master01 7.6. ...
- [CoreOS 转载]CoreOS实践指南(二):架设CoreOS集群
转载:http://www.csdn.net/article/2015-01-04/2823399 摘要:CoreOS是一个采用了高度精简的系统内核及外围定制的操作系统.ThoughtWorks的软件 ...
- Ambari安装之部署3个节点的HA分布式集群
前期博客 Ambari安装之部署单节点集群 其实,按照这个步骤是一样的.只是按照好3个节点后,再做下HA即可. 部署3个节点的HA分布式集群 (1)添加机器 和添加服务的操作类似,如下图 之后的添加a ...
随机推荐
- wap网页、微信内嵌网页在手机端页面窗口尺寸如何不缩放
如何让wap网页.微信内嵌网页内容(尺寸和文字)在手机端页面窗口尺寸不被强制缩放 在head中加入: <meta http-equiv="Content-Type" cont ...
- 数据库SQL,NoSQL之小感悟
遇到1000万数据表 最近遇到一个问题,就是单表数据过的存储及查询问题.举个例子:1000万的数据存在一个表中,字段4-5个样子,日常 开发中难免要做过滤.排序.分页.如果把这几个放在一起即要过滤又要 ...
- sed 命令详解
sed 用于筛选和转换文本的流编辑器 描述: sed是一个流编辑器,流编辑器对一个输入流执行基本的文本转换(输入流来自文件或者管道行).虽然在某些方面类似于很多可运行脚本的编辑器,但是sed的工作方式 ...
- 使用批处理根据项目工程文件生成Nuget包并发布(支持.NET Core)
最近在使用之前自己编写的批处理给.NET Core项目打包时出问题了,发现之前的脚本根本不适用了,折腾了半天,总算解决了.因此在这里分享下经验,并且奉上整理好的脚本. Nuget包这里就不多介绍了,需 ...
- 使用光盘iso实现Linux操作系统的自动安装部署
前边写了一篇使用 PXE 的方式批量安装操作系统,不是任何时候任何地方都有环境来通过 PXE 方式来进行安装.如果此时需要通过光盘安装,默认的情况下是通过交互式方式进行安装,其实也可以通过 kicks ...
- 怎样的 Hash 算法能对抗硬件破解
前言 用过暴力破解工具 hashcat 的都知道,这款软件的强大之处在于它能充分利用 GPU 计算,比起 CPU 要快很多.所以在破解诸如 WiFi 握手包.数据库中的口令 Hash 值时,能大幅提高 ...
- Extjs grid 组件
表格面板类Ext.grid.Panel 重要的配置参数 columns : Array 列模式(Ext.grid.column.Columnxtype: gridcolumn) 重要的配置参数 tex ...
- 在CentOS 7中安装Redis 3.2.8
文章环境: CentOS 7 biuld 1611最小化安装@VMware Redis 3.2.8 安装步骤: #安装gcc yum -y install gcc #下载redis curl -O h ...
- 第二章:JavaScript对象
一.window对象 1.属性 2.方法 二.history对象 1.方法 三.location对象 1.属性 2.方法 四.Document对象 1.属性 2.方法
- 零基础HTML编码学习笔记
任务目的 了解HTML的定义.概念.发展简史 掌握常用HTML标签的含义.用法 能够基于设计稿来合理规划HTML文档结构 理解语义化,合理地使用HTML标签来构建页面 任务描述:完成一个HTML页面代 ...