利用前面写的一键部署nginx脚本,一键安装nginx,启动nginx服务,关闭防火墙
查看nginx配置文件,每个server代表一个虚拟主机
我们部署多个虚拟主机就复制多套server
修改配置文件的访问域名和网站的发布地址
新建两个发布目录
mkdir -p /data/webapps/www{1,2}
分别在两个发布目录下新建两个测试页面,重新加载配置文件,并且重启nginx服务
在本地主机添加hosts解析,在如下目录下,添加如下两个域名解析
需要管理员权限进行编辑,即可成功访问
可以将v1的页面修改为百度的访问页面,即把index文件修改为百度文件即可
也可把虚拟主机单独放到一个文件里面 ,用include引入配置文件即可
重新加载配置文件,重启nginx服务,即可成功访问网站
编辑命令cat<<EOF EOF 等价于echo
将内容添加到某个文件,打印出来模式为cat>/tmp/list.txt<<EOF EOF
用以下代码将yum install -y替换为NGX_YUM
%s#yum install -y#$NGX_YUM#g
修改之前的自动安装nginx版本
!/bin/bash
echo "1.输入参数1为安装nginx"
echo "2.输入参数2为升级或降级nginx"
echo "3.输入参数3为卸载nginx"
read -p "请输入您选择的数字: " input
NUM1=$input
NGX_VHOST="v1.xin.net"
NGX_YUM="yum install -y"
NGX_CNF="nginx.conf"
NGX_ROOT_DIR="/data/webapps"
NGX_DIR="/usr/local/nginx"
if [ "$NUM1" == 1 ];then
echo 您输入的数字为$NUM1,为您执行安装nginx
read -p "请输入您要安装的版本号: " input
NGX_VER=$input
NGX_SRC="/usr/src/"
NGX_SOFT="nginx-${NGX_VER}.tar.gz"
NGX_URL="http://nginx.org/download"
NGX_ARGS="--user=www --group=www --with-http_stub_status_module"
CHECK_NUM=$(rpm -qa|grep -E "tar|gcc|pcre-devel|zlib-devel|make"|wc -l)
if [ $CHECK_NUM -lt 9 ];then
#提前解决Nginx编译所需依赖环境、库文件
$NGX_YUM gcc tar make pcre-devel zlib-devel openssl-devel
else
echo "依赖和库文件已经存在,跳过安装,进行下一步"
fi
if [ ! -d $NGX_DIR ];then
#从Nginx官网下载软件包;
wget -c $NGX_URL/$NGX_SOFT -P $NGX_SRC
#Cd切换至/usr/src/;
cd $NGX_SRC
ls -l $NGX_SOFT
#通过Tar工具对其解压;
tar -xzvf $NGX_SOFT
#Cd切换至Nginx源代码目录;
cd nginx-$NGX_VER/
#创建www用户和组,解决依赖环境、库文件;
useradd -s /sbin/nologin www -M
#预编译;
./configure --prefix=$NGX_DIR/ $NGX_ARGS
#编译;
make -j4
#安装;
make -j4 install
#查看Nginx软件服务是否部署成功;
ls -l $NGX_DIR/
#启动Nginx服务进程;
$NGX_DIR/sbin/nginx
#查看Nginx进程状态;
ps -ef|grep nginx
#关闭Firewalld防火墙;
systemctl stop firewalld.service
else
echo "Nginx WEB已经安装,请检查并退出执行"
/usr/local/nginx/sbin/nginx -s reload
echo "nginx重启成功"
ls -ld $NGX_DIR
ls -l $NGX_DIR
fi
else
if [ "$NUM1" == 2 ];then
echo 您输入的数字为$NUM1,为您执行升级或降级操作
read -p "请输入您要安装的版本号: " input
NGX_VER=$input
NGX_SRC="/usr/src/"
NGX_SOFT="nginx-${NGX_VER}.tar.gz"
NGX_URL="http://nginx.org/download"
NGX_ARGS="--user=www --group=www --with-http_stub_status_module"
CHECK_NUM=$(rpm -qa|grep -E "tar|gcc|pcre-devel|zlib-devel|make"|wc -l)
if [ $CHECK_NUM -lt 9 ];then
#提前解决Nginx编译所需依赖环境、库文件
$NGX_YUM gcc tar make pcre-devel zlib-devel openssl-devel
else
echo "依赖和库文件已经存在,跳过安装,进行下一步"
fi
#从Nginx官网下载软件包;
wget -c $NGX_URL/$NGX_SOFT -P $NGX_SRC
#Cd切换至/usr/src/;
cd $NGX_SRC
ls -l $NGX_SOFT
#通过Tar工具对其解压;
tar -xzvf $NGX_SOFT
#Cd切换至Nginx源代码目录;
cd nginx-$NGX_VER/
#创建www用户和组,解决依赖环境、库文件;
useradd -s /sbin/nologin www -M
#预编译;
./configure --prefix=$NGX_DIR/ $NGX_ARGS
#编译;
make -j4
#将生成的nginx二进制文件覆盖其原文件
mv $NGX_DIR/sbin/nginx $NGX_DIR/sbin/nginx.old
\cp objs/nginx $NGX_DIR/sbin/nginx
#重启Nginx服务进程;
\cd $NGX_DIR/sbin/
\.\/nginx -s reload
echo 您已重新启动nginx,完成升级或降级操作
#查看Nginx进程状态;
ps -ef|grep nginx
#关闭Firewalld防火墙;
systemctl stop firewalld.service
else if [ "$NUM1" == 3 ];then
echo 您输入的数字为$NUM1,为您执行卸载操作
#停止Nginx进程
cd $NGX_DIR/sbin/
\.\/nginx -s stop
pkill nginx
rm -rf $NGX_DIR
#find / -name "nginx*" -exec rm -rf {} \;
else
echo 您输入的数字为$NUM1,没有该操作,请检查后重新操作
exit
fi
fi
fi
#虚拟主机配置
cd /usr/local/nginx/conf/
#备份$NGX_CNF文件 cp前面加\为强制拷贝的意思
\cp $NGX_CNF $NGX_CNF.bak
#修改$NGX_CNF配置文件,加入include vhosts代码:
#不能用vi,vim 交互模式编辑
cat>$NGX_CNF<<EOF
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
include vhosts/*;
}
EOF
#创建vhosts虚拟机主机目录&配置文件:
mkdir -p vhosts
cd vhosts/
touch $NGX_VHOST
cat>$NGX_VHOST<<EOF
server {
listen 80;
server_name $NGX_VHOST;
location / {
root $NGX_ROOT_DIR$NGX_VHOST;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
EOF
#创建$NGX_VHOST
mkdir -p $NGX_ROOT_DIR/$NGX_VHOST/
#在$NGX_VHOST发布目录创建index.html文件
cat>$NGX_ROOT_DIR/$NGX_VHOST/index.html<<EOF
$NGX_VHOST 2024 test pages.
EOF
#重启nginx服务进程
$NGX_DIR/sbin/nginx -s reload
echo 重启nginx服务成功
重启成功后即可访问域名成功