我了解到的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