nginx功能梳理

我了解到的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.csdn.net/myle69/article/details/83512617

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值