nginx功能梳理

本文介绍了nginx的六大功能:反向代理、正向代理、负载均衡、容错、动静分离及健康检查。通过反向代理实现用户与服务的间接交互,正向代理帮助用户访问受限服务。负载均衡和容错确保系统稳定性,动静分离优化HTTP服务器性能,健康检查则通过nginx_upstream_check_module进行。同时,nginx还具备限流功能,如ngx_http_limit_req_module和ngx_http_limit_conn_module分别限制请求速率和连接数。

我了解到的nginx的功能有这些:反向代理/正向代理/负载均衡/容错/动静分离/健康检查/限流

1. 反向代理

用户不知道,也不关注具体请求哪个服务,用户只与nginx服务器交互,由nginx控制具体发往哪个服务。
在这里插入图片描述

2. 正向代理
与反向代理不一样的是,此时用户知道自己想与服务1/服务2/服务3沟通,但是由于某些原因无法直接沟通,于是通过代理服务器(nginx)来实现。

server {
	   listen 9999;
	
	   location /service1 {
	       proxy_pass http://service1.com/service1;
	   }
	   location /service2 {
	       proxy_pass http://service2.com/service2;
	   }
	   location /service3 {
	       proxy_pass http://service3.com/service3;
	   }
}

如上配置nginx后,用户事先将代理服务器设置为nginx:9999,然后所有访问请求将被转发到nginx服务器,由nginx替用户来请求。

3. 负载均衡/容错

upstream myserver{ 
	# weight表示权重,max_fails表示最大错误次数,fail_timeout表示失败后服务暂停时间
    server 127.0.0.1:8080 weight=2 max_fails=2 fail_timeout=2; 
    server 127.0.0.1:8081 weight=1 max_fails=2 fail_timeout=1;    
    server 127.0.0.1:8082 down; # 此服务器暂时不可使用
    server 127.0.0.1:8083 backup; # 此服务作为backup,当其余服务宕掉(connect refuse/timeout)时使用
    ip_hash; # 根据ip hash来分配服务器,默认是按比重轮询,还有fair,url_hash等,由第三方提供
}

4. HTTP服务器(动静分离)
传统的java应用,使用tomcat服务器,动态请求和静态文件均请求tomcat。
使用nginx,则可以将动态请求转发至tomcat,将静态文件请求直接指向本地文件夹。

5. 健康检查
nginx_upstream_check_module模块(第三方)可以提供比较好的健康检查功能。

upstream myserver {
	server 127.0.0.1:8080;
	server 127.0.0.1:8081;
	#http健康检查相关配置
	check interval=3000 rise=2 fall=3 timeout=3000 type=http;
	#/health/status为后端健康检查接口
	check_http_send "HEAD /health/status HTTP/1.0";
	check_http_expect_alive http_2xx http_3xx;
}

以上配置引自https://www.cnblogs.com/handsomeye/p/9604785.html

6. 限流
ngx_http_limit_req_module 模块提供限制请求处理速率能力,使用了漏桶算法(leaky bucket)
ngx_http_limit_conn_module 提供了限制连接数的能力,利用 limit_conn_zone 和 limit_conn 两个指令即可。
参考:https://blog.youkuaiyun.com/myle69/article/details/83512617

基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值