深入Nginx之《常用参数配置技巧》

常见参配置实战技巧

    下面会讲解实战中应该怎么配置更为合理。


 

1.user

    默认是nobody,如果使用nobody,Nginx在运行过程中会出现很多操作没有权限,比如写硬盘。一般都是用低于root级别的用户,比如www,并且可以在linux下设置www禁止ssh登录服务器,提高安全性;

 

2.worker_processes

    代表Nginx worker的进程数,一般情况下建议和机器的核数相同,也可以配置 worker_processes auto ; (Nginx1.2.5版本添加的) 自动根据cpu核数进行进程启动;

    但是实际应用中,服务器不一定只跑了Nginx,需要考虑机器资源会被分配到哪些服务上,避免进程启动过多,和其他服务竞争cpu,导致过多上下文切换;

 

3.worker_cpu_affinity auto

Nginx 1.9.10添加的功能,表示可以根据服务器的核数自动配cpu亲缘性,提升Nginx的性能;

 

4、error_log & access_log

关于日志记录的,error_log 配置为error级别, 减少不必要的日志记录, 如果是测试环境可以开启info级别。日志记录需要考虑硬盘的独立性,不要使用linux的根分区,避免大量的io影响Linux服务器吞吐能力。单独挂载一个磁盘,独立使用io;

另外硬盘的使用寿命需要注意,关注message的日志,定期检查硬盘(Nginx记录日志是异步处理,并且不会因为硬盘的问题,导致请求异常,但是会影响日志的记录) ;

 

5.worker_priority

    配置Nginx在linux服务器上资源使用的优先级,作为反向代理服务,应该拥有极高的优先级,建议配置到-10;

 

6.gzip_comp_level

    压缩等级,等级最高为9,等级越高压缩后的文件越小,但是消耗的cpu也会更多,经过测试,压缩等级7 和 9 的文件大小相比,其实只有细微的差别,用5-7的等级足矣;

 

7.upstream块

    配置上游服务器,可以结合 proxy_next_upstream 等指令做大量的优化,我会在下面的章节单独说明;

 

8.error_page

    错误重定向,可以捕获上游服务器错误的状态码后,将请求重定向到其它地方,比如提供友好页面,关于error_page的更强大的使用方式。

 

9.location & root

    通过root路径可以读取静态文件,在1.7.11以前的版本,Nginx读取硬盘的文件,都是阻塞型操作,后面引入了线程池,使得读取硬盘提供了非阻塞的操作,极大的提升了硬盘的io,也提升了proxy_cache的能力。

Nginx的常见配置在使用中都有着不同的变化,那么对于更为复杂的配置来说,其配置就显得更为精妙了,所以熟悉Nginx的官方wiki是发挥它巨大作用的基础。

 

常见配置注解


 

user  www www;   

    #定义Nginx运行的用户和用户组

worker_processes  2;    

    #Nginx进程数

worker_cpu_affinity auto;    

    #配置Nginx进程cpu亲源性

error_log  /var/log/error_log  info;    

    #全局错误日志定义类型 ,默认是error

worker_rlimit_nofile 65535;    

    #一个Nginx进程打开的最多文件描述符数量

pid /var/run/nginx.pid;    

    #进程文件

worker_priority -10;    

    #linnx系统下的资源使用的优先级

worker_rlimit_nofile  65535;    

    #worker进程的最大打开文件数限制

worker_shutdown_timeout  30;    

    #30s内Nginx无法平滑退出,就强行关闭进程

events {

  worker_connections  10000;    

    #单个进程最大连接数(整个Nginx最大连接数=连接数*进程数)

  use epoll;    

    #epoll linux2.6+内核高性能的网络io, 如果跑在FreeBSD上面,就用kqueue模型。

}

 

http {

    include       conf/mime.types;    

    #文件扩展名与文件类型映射表

    default_type  application/octet-stream;     

    #默认文件类型

    log_format main     '$remote_addr - $remote_user [$time_local] '

                         '"$request" $status $bytes_sent '

                         '"$http_referer" "$http_user_agent" '

                         ‘"$http_cookie"';   

    #定义日志格式

    client_header_buffer_size    1k;    

    #设置用户请求头所使用的buffer大小

    large_client_header_buffers  4 4k;    

    #当默认的缓冲不够用时就会使用此参数。

    server_names_hash_bucket_size 128;    

    #服务器名字的hash表大小

    client_header_buffer_size 32k;    

    #上传文件大小限制

    gzip on;    

    #开启gzip

    gzip _comp_level 6;    

    #压缩等级

    gzip _min_length  1100;    

    #设置允许压缩的页面最小字节数

    gzip _buffers     4 8k;    

    #设置系统获取几个单位的缓存用于存储gzIP的压缩结果数据流。4 8k 代表以8k为单位,按照原始数据大小以8k为单位的4倍申请内存。

    gzip _types       text/plain text/css;    

    #匹配MIME类型进行压缩

    output_buffers   2 32k;    

    #设置用于从磁盘读取响应的缓冲区的数量和大小。 此设置为:按照原始数据大小以32K为单位的2倍大小申请内存空间。

    sendfile         on;    

    #启用sendfile()函数

    tcp_nopush       on;    

    #防止网络阻塞,需要sendfile开启

    tcp_nodelay      on;    

    #防止网络阻塞,需要sendfile开启

    keepalive_timeout 90s;    

    #长连接超时时间,单位是秒

    upstream backend {

    server 192.168.1.12:8081 weight=3;

    server 192.168.1.13:8081 weight=2;

    #upstream块,weight是权重,权重越高,请求的比例越高。 

    server {

        listen       80;     

         #http监听端口

        server_name  your.example.com;  

        #域名

        access_log   /var/log/nginx.access_log  main;     

        #访问日志记录

        charset  koi8-r;    

        #默认编码

        location / {

            proxy_pass         http://backend ;

            proxy_redirect     off;

            proxy_set_header   Host             $host;

            proxy_set_header   X-Real-Ip       $remote_addr;

            proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;       }    

        #后端的应用服务器通过X-Forwarded-For获取用户的真实IP

        error_page  404  /404.html;    

        #对于后端应用服务器抛出的错误404 进行页面重定向

        location /404.html {

            root  /spool/www;

        } 

        # 匹配URL为jpg,jpeg,gif结尾的,直接去系统文件读取

        location ~* \.(jpg|jpeg|gif)$ {

            root         /spool/www;

            expires      30d;    

        #浏览器缓存的时间

        }

    }

转载于:https://www.cnblogs.com/dtdxrk/p/9438497.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/249777.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

transform、transition 动画效果

transform 转换,变形 origin 定义旋转基点(left top center right bottom 坐标值) transform-origin: 50px 50px; transform-origin: left;。 rotate 旋转 transform:rotate(50deg) 旋转角度可以为负数,需要先定义…

eslint 规则

"off"或0- 关闭规则 "warn"或1- 将规则作为警告打开(不影响退出代码) "error"或2- 将规则作为错误打开(触发时退出代码为1)转载于:https://www.cnblogs.com/smzd/p/10844161.html

分布式学习路线

由于分布式系统所涉及到的领域众多,知识庞杂,很多新人在最初往往找不到头绪,不知道从何处下手来一步步学习分布式架构。 本文试图通过一个最简单的、常用的分布式系统,来阐述分布式系统中的一些基本问题。 负载均衡分布式缓存分…

洛谷p2704 炮兵阵地

典型的状态压缩题&#xff0c;只是要定义dp[i][j][k]&#xff0c; #include<bits/stdc.h>using namespace std;int n,m,state[1<<10],tot0;int dp[110][66][66],sum[1<<10],mp[110];int getsum(int x){ int cnt0; while(x){ if(x&1) cnt; …

Flask 框架app = Flask(__name__) 解析

1 #!/usr/local/bin/python2 # codingutf-83 4 from flask import Flask5 app Flask(__name__)6 7 app.route(/)8 def hello_world():9 return Hello World! 10 11 if __name__ __main__: 12 app.run(host0.0.0.0,port9000) 第4行&#xff0c;引入Flask类&#x…

发布订阅

发布订阅 在软件架构中&#xff0c;发布订阅是一种消息范式&#xff0c;消息的发送者&#xff08;称为发布者&#xff09;不会将消息直接发送给特定的接收者&#xff08;称为订阅者&#xff09;。而是将发布的消息分为不同的类别&#xff0c;无需了解哪些订阅者&#xff08;如果…

ps 命令

ps 为我们提供了进程的一次性的查看&#xff0c;它所提供的查看结果并不动态连续的&#xff1b;如果想对进程时间监控&#xff0c;应该用 top 工具。kill 命令用于杀死进程。linux上进程有5种状态: 1. 运行(正在运行或在运行队列中等待) 2. 中断(休眠中, 受阻, 在等待某个条件的…

python练习题-day8

1、有如下文件&#xff0c;a1.txt&#xff0c;里面的内容为&#xff1a; 老男孩是最好的培训机构&#xff0c; 全心全意为学生服务&#xff0c; 只为学生未来&#xff0c;不为牟利。 我说的都是真的。哈哈 分别完成以下的功能&#xff1a; a,将原文件全部读出来并打印。 with o…

消息中间件应用场景

消息中间件应用场景

IDEA开发vue.js卡死问题

在执行cnpm install后会在node_modules这个文件下面生成vue的相关依赖文件&#xff0c; 这个时候当执行cnpm run dev命令时&#xff0c;会导致IDEA出现卡死的问题&#xff0c;解决方法如下&#xff1a; 转载于:https://www.cnblogs.com/heqiuyong/p/10301925.html

[BZOJ4698][SDOI2008]Sandy的卡片(后缀自动机)

差分之后就是求多串LCS。 对其中一个串建SAM&#xff0c;然后把其它串放在上面跑。 对SAM上的每个状态都用f[x]记录这个状态与当前串的最长匹配长度&#xff0c;res[x]是对每次的f[x]取最小值。答案就是res[]的最大值。 考虑f[x]的求法&#xff0c;把s[]放在SAM上跑时&#xff…

点对点

数据传输的可靠性是通过数据链路层和网络层的点对点和传输层的端对端保证的。点对点是基于MAC地址或者IP地址&#xff0c;是指一个设备发数据给另外一个设备&#xff0c;这些设备是指直连设备包括网卡&#xff0c;路由器&#xff0c;交换机。端对端是网络连接&#xff0c;应用程…

none

module.exports {root: true,env: {node: true},extends: [plugin:vue/essential, vue/prettier],rules: {no-console: process.env.NODE_ENV production ? error : off,no-debugger: process.env.NODE_ENV production ? error : off,prettier/prettier: [error,{// tab缩…

MQ消息中间件介绍

消息队列技术是分布式应用间交换信息的一种技术&#xff0c;消息队列可驻留在内存或者磁盘上&#xff0c;队列存储消息直到它们被应用程序读走&#xff0c;通过消息队列&#xff0c;应用程序可以独立的执行—它们不需要知道彼此的位置&#xff0c;或者继续执行前不需要等待接收…

22 块级元素和行内元素

学习的初期&#xff0c;我们就要知道&#xff0c;标准文档流等级森严。标签分为两种等级&#xff1a; 行内元素块级元素比如h1标签和span&#xff0c;同时设置宽高&#xff0c;来看浏览器效果&#xff0c;那么你会发现&#xff1a; 行内元素和块级元素的区别&#xff1a;&#…

节流防抖

https://www.cnblogs.com/fsjohnhuang/p/4147810.html 转载于:https://www.cnblogs.com/smzd/p/10943002.html

P3796 【模板】AC自动机(加强版)

题目描述 有 NNN 个由小写字母组成的模式串以及一个文本串 TTT 。每个模式串可能会在文本串中出现多次。你需要找出哪些模式串在文本串 TTT 中出现的次数最多。 输入输出格式 输入格式&#xff1a;输入含多组数据。 每组数据的第一行为一个正整数 NNN &#xff0c;表示共有 NNN…

访问数据库优化

例如&#xff1a;工资表里面有全公司人员的工资信息。 现在我需要把这些工资信息打印成工资条。因此需要访问数据库。 1.把整个表全部读取出来&#xff0c;内存处理每个人的工资信息。 2.按照人员单个查询每个人的工资信息。 分析&#xff1a;第一种情况是将所有的人员全部查询…

psql 命令

&#xff08;1&#xff09;使用命令行连接数据库psql -U postgres -h localhost -p 5433 &#xff08;2&#xff09;列出所有的数据库\l -- 查看所有数据库&#xff08;3&#xff09;进入某个数据库\c name -- name是表名(4)列出数据库的所有数据表和视图\d -- 列出所有的数据…

各种缓存介绍

说起缓存相关技术&#xff0c;老多了&#xff0c; memcache、redis、squid、varnish、web cache、 CDN等等。缓存技术五花八门&#xff0c;但这些技术间有什么共性的地方&#xff0c;又有什么不同的地方呢&#xff1f;答案肯定是有的&#xff0c;这次为大家分享及整理一下缓存方…