通过几段nginx配置提升应用的健壮性和降低出口带宽

简介: nginx是目前比较流行的web服务,通过nginx中的一些配置不仅能提升应用的健壮性,更能降低出口带宽节省成本。

1.通过以下nginx配置提升应用的健壮性

1.1、超时及后端重试次数配置

    proxy_next_upstream_tries 4; #结合proxy_next_upstream使用,用于后端重试次数。如果是tengine参数则是:proxy_upstream_tries
    proxy_connect_timeout    10; #nginx到后端连接超时时间。
    proxy_read_timeout       15; #nginx后端读取数据的超时时间。
    proxy_send_timeout       60; #nginx发送数据到后端的超时时间
    proxy_next_upstream http_500 http_502 http_504 error timeout invalid_header; #当请求后端出现500、502、504状态码时,继续发送请求到下一台后端服务器重试,需配置proxy_next_upstream_tries,否则当失败时会重试所有后端服务器。

1.2、upstream的健康监测

   upstream WEB_APP {
        server 172.16.99.197:8080 max_fails=5 fail_timeout=5s; #表示在5秒[fail_timeout]内,失败了5次[max_fails],在这期间不会发送请求到此服务器。请根据实际情况合理配置该参数:避免出现"no live upstream"的告警,出现502请求。
        server 172.16.99.198:8080 max_fails=5 fail_timeout=5s;
        server 172.16.99.199:8080 max_fails=5 fail_timeout=5s;
        #以下这部分配置是出自阿里云开源的tengine,能对后端进行主动监测并屏蔽掉故障的后端,避免请求发送到故障的机器,使用tengine或增加此模块才可配置这段。
        check interval=3000 rise=2 fall=3 timeout=3000 type=http;
        check_http_send "HEAD /s/monitor.js HTTP/1.0\r\n\r\n";
        check_http_expect_alive http_2xx http_3xx;
    }

注:check各参数详细说明,可以参见阿里云开源的tengine地址:tengine

2.通过以下nginx配置降低出口带宽

开启压缩以后,大部份静态文件压缩后的大小大概原来的1/8左右。这对于请求量巨大的情况下能节省下不少出口带宽。
    gzip  on;  #压缩开关、关闭:off
    gzip_disable "msie6"; #排除不需要压缩的浏览器
    gzip_min_length  1k; #当返回的content-length大于此值时开启压缩
    gzip_buffers     4 16k; #压缩缓冲区设置
    gzip_http_version 1.0; #开启压缩的HTTP协议版本
    gzip_comp_level 9; #压缩的级别1-9,默认为1.
    gzip_types  text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;  #支持压缩的mime类型
    gzip_vary on; #在http响应头中返回Vary: Accept-Encoding标头
    gzip_proxied any; #作为反向代理时针对上游的header头值进行压缩,此处的any表示都压缩
相关文章
|
23天前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
30天前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
246 0
|
2天前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
15天前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
nginx配置反向代理404问题
|
10天前
|
应用服务中间件 网络安全 PHP
八个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
Nginx 是一个高效的 HTTP 服务器和反向代理,擅长处理静态资源、负载均衡和网关代理等任务。其配置主要通过 `nginx.conf` 文件完成,但复杂设置可能导致错误。本文介绍了几个开源的 Nginx 可视化配置系统,如 Nginx UI、VeryNginx、OpenPanel、Ajenti、Schenkd nginx-ui、EasyEngine、CapRover 和 NGINX Agent,帮助简化和安全地管理 Nginx 实例。
|
20天前
|
缓存 负载均衡 应用服务中间件
Nginx配置
【10月更文挑战第22天】在实际配置 Nginx 时,需要根据具体的需求和环境进行调整和优化。同时,还需要注意配置文件的语法正确性和安全性。
35 7
|
29天前
|
前端开发 JavaScript 应用服务中间件
终极 Nginx 配置指南
本文介绍了Nginx的基本配置及其优化方法。首先,通过删除注释简化了Nginx的默认配置文件,使其更易于理解。接着,文章将Nginx配置文件分为全局块、events块和http块三部分进行详细解释。此外,还提供了如何快速上线网站、解决前端history模式404问题、配置反向代理、开启gzip压缩、设置维护页面、在同一IP上部署多个网站以及实现动静分离的具体配置示例。最后,附上了Nginx的基础命令,包括安装、启动、重启和关闭等操作。
|
1月前
|
缓存 前端开发 JavaScript
一、nginx配置
一、nginx配置
148 1
|
30天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
136 0
|
1月前
|
缓存 监控 负载均衡
nginx相关配置及高并发优化
Nginx的高并发优化是一个综合性的过程,需要根据具体的业务场景和硬件资源量身定制。以上配置只是基础,实际应用中还需根据服务器监控数据进行持续调整和优化。例如,利用工具如ab(Apache Benchmarks)进行压力测试,监控CPU、内存、网络和磁盘I/O等资源使用情况,确保配置的有效性和服务的稳定性。
107 0