Nginx动静分离、高可用集群

1、动静分离

1) 什么是动静分离

在这里插入图片描述
通过 location 指定不同的后缀名实现不同的请求转发。通过 expires 参数设置,可以使浏
览器缓存过期时间,减少与服务器之前的请求和流量。
具体 Expires 定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。此种方法非常适合不经常变动的资源。(如果经常更新的文件,不建议使用 Expires 来缓存),我这里设置 3d,表示在这 3 天之内访问这个 URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码 304,
如果有修改,则直接从服务器重新下载,返回状态码 200。

2)准备SpringBoot项目

① 引入thymeleaf依赖
②在静态资源文件夹static中分别创建css、images、js资源文件
在tmeplates中创建一个index.html,在该html中引用自创建的css、images、js资源文件
在这里插入图片描述③ 编写controller

@GetMapping("demo")
    public String demo(){
        return "index";
    }

④ 启动项目,访问demo,测试结果

⑤ 测试成功,将static包中的资源文件删除,将项目打包成jar文件,发布到Linux上
在这里插入图片描述⑥ 将static资源文件夹,放入到nginx的根目录中
在这里插入图片描述
⑦ 修改nginx的配置文件,添加如下内容
在这里插入图片描述⑧ 启动nginx,浏览器访问demo,可以得到静态资源文件

2、Nginx的高可用集群

1) 什么是高可用

在这里插入图片描述

2)环境搭建

①两台Linux虚拟机
可以直接clone,但是需要修改IP地址,两台虚拟机的ip要保持不一致
②在两台虚拟机上下载keepalived
使用yum命令进行安装

# 下载keepalived
yum install keepalived –y
# 查看keepalived是否安装成功
rpm -q -a keepalived

安装之后,在 etc 里面生成目录 keepalived,有文件 keepalived.conf

③配置虚拟ip
修改Keepalived.conf配置文件

global_defs {
	 notification_email {
	 acassen@firewall.loc
	 failover@firewall.loc
	 sysadmin@firewall.loc
	 }
	 notification_email_from Alexandre.Cassen@firewall.loc
		 # 修改成虚拟机的ip
		 smtp_server 192.168.75.34
		 smtp_connect_timeout 30
		 # 主机的名称,可以改成ip
		 router_id 192.168.75.34
}
vrrp_script chk_http_port {
	 # 脚本文件的绝对路径
	 script "/usr/local/src/nginx_check.sh"
	 interval 2 #(检测脚本执行的间隔)
	 weight 2
}
vrrp_instance VI_1 {
	 # 备份服务器上将 MASTER 改为 BACKUP 
	 state MASTER 
	 # 可以使用ip addr查看自己的网卡
	 interface ens33 
	 # 主、备机的 virtual_router_id 必须相同
	 virtual_router_id 51 
	 priority 90 # 主、备机取不同的优先级,主机值较大,备份机值较小
	 advert_int 1
	 authentication {
	 auth_type PASS
	 auth_pass 1111
}
 virtual_ipaddress {
     # 配置的虚拟ip
	 192.168.75.50 
} 

创建脚本文件,要在Keepalived.conf配置文件中写的路径保持一致

vrrp_script chk_http_port {
	 # 脚本文件的绝对路径
	 script "/usr/local/src/nginx_check.sh"
	 interval 2 #(检测脚本执行的间隔)
	 weight 2
}

在/usr/local/src/路径下创建文件nginx_check.sh

# 进入到文件路径下
cd /usr/local/src
# 创建文件
vim nginx_check.sh

文件内容如下

#!/bin/bash
A=`ps -C nginx –no-header |wc -l`
if [ $A -eq 0 ];then
  # nginx执行文件的绝对路径
 /usr/java/nginx/sbin/nginx
 sleep 2
 if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
        killall keepalived
 fi
fi

保存退出,然后修改一下文件的权限

[root@localhost src]# chmod 775 /usr/local/src/nginx_check.sh 

在keepalived.conf的global_defs中添加 两行代码

 script_user root
 enable_script_security

④ 开启服务
两台虚拟机分别开启nginx和keepalived

# 开启nginx
./nginx
# 开启keepalived
systemctl start keepalived.service

⑤ 测试
地址栏访问配置的虚拟ip
显示主机的欢迎页面
在这里插入图片描述
现在让34主机宕机,
停止nginx服务和keepalived服务

./nginx -s stop
systemctl stop keepalived.service

重新地址栏访问虚拟ip
在这里插入图片描述现在显示的35备机

3、Nginx的原理

1)Master&Worker

在这里插入图片描述

2)Worker如何工作的

在这里插入图片描述

3)一个Master,多个Worker 的好处

  • (1)可以使用 nginx –s reload 热部署,利用 nginx 进行热部署操作
  • (2)每个 woker 是独立的进程,如果有其中的一个 woker 出现问题,其他 woker 独立的,
    继续进行争抢,实现请求过程,不会造成服务中断

4) 设置多少个Worker合适

worker 数和服务器的 cpu 数相等是最为适宜的

5)连接数worker-connection

第一个:发送请求,占用了 woker 的几个连接数?
答案:2 或者 4 个
第二个:nginx 有一个 master,有四个 woker,每个 woker 支持最大的连接数 1024,支持的
最大并发数是多少?
 普通的静态访问最大并发数是: worker_connections * worker_processes /2,  而如果是 HTTP 作 为反向代理来说,最大并发数量应该是 worker_connections *
worker_processes/4。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值