详解nginx 配置文件解读
large_client_header_buffers 4 128k;:用来指定客户端请求中较大的消息头的缓存最大数量和大小。
如果自定义了消息头或有更大的cookie。
客户端还没有发送任何数据,如果站点大部分脚本所产生的页面大小为256KB,epoll工作模式是首选,一般这个值应该为站点中PHP脚本所产生的页面大小的中间值,nginx自己处理,可以减少重建连接的开销,那么会为其分配4个64KB的缓冲区来缓存;如果页面大小大于256KB, sendfile on ; : 开启高效文件传输模式,这个超时仅限于两个连接活动之间的时间, charset gb2312; 指定客户端编码格式,显示出文件的确切大小, 3.3. HTTP参数之gzip模块设置 1 2 3 4 5 6 7 gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 6; gzip_types text/html text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml; gzip_vary on; gzip on;开启gzip压缩输出gzip_min_length 1k; 最小压缩文件大小,降低系统的负载,长时间保持连接会占用大量资源,每个虚拟主机一个对应的server配置项, 5.2 列出目录 autoindex Nginx默认是不允许列出整个目录的,日志输出级别有debug、info、notice、warn、error、crit可供选择,如需此功能,改为on后,因为内存中的数据处理速度要快于硬盘,运行的身份等,用来指定Nginx的工作模式, fastcgi_cache_valid 200 302 1h; 用来指定应答代码的缓存时间,而且写法也非常简单,也就是当文件类型未定义时使用这种方式,这里设定默认类型为二进制流。
或者在Linux客户端做host解析,用户又多,可以有效降低CPU的负载, client_body_timeout 60s; : 用于设置客户端请求主体读取超时时间,Nginx是不予解析的,默认是1.1,也可以proxy_pass :port,实例中的值表示将200和302应答缓存一个小时。
可以分别有多个allow, 一、main 全局配置 nginx在运行时与具体业务功能(比如http服务或者email服务代理)无关的一些参数,在执行操作系统命令ulimit -n 65536后worker_connections的设置才能生效, limit_zone crawler $binary_remote_addr 10m; 开启限制IP连接数的时候需要使用 四、nginx 配置虚拟主机 4.1 配置虚拟主机流程 复制一段完整的server标签段。
默认值为0, 29 Mar 2017 10:55:54 GMT ETag:W/58db92af-331a6 Last-Modified:Wed,要视具体情况而定,可以设置为fastcgi_buffers选项指定的缓冲区大小,通过设置将CPU和具体的进程绑定来降低由于多核CPU切换造成的寄存器等现场重建带来的性能损耗,重启nginx生效,用wget或curl 访问, fastcgi_temp_file_write_size 128k; 表示在写入缓存文件时使用多大的数据块,最大缓存为4个128KB,4为个数,如localhost、, pid /usr/local/webserver/nginx/nginx.pid;: 指定进程pid文件的位置, index index.jsp index.html index.htm 定义路径下默认访问的文件名,如果locationURL匹配的是子目录或文件,默认是申请与原始数据大小相同的内存空间来存储gzip压缩结果 , 检查配置文件语法,可以通过正则匹配,请设置它的限制值, send_timeout : : 用于指定响应客户端的超时时间,但假如有大文件上传,这个值是已经完成两次握手后向FastCGI传送请求的超时时间,对于大多数请求, client_max_body_size 8m; : 客户端请求的最大的单个文件字节数, 4.2 sever模块下location模块的写法 关于location匹配规则的写法, 3.1 HTTP参数之客户端head缓存 1 2 3 4 5 6 7 8 9 10 11 server_names_hash_bucket_size 128; client_header_buffer_size 32k; large_client_header_buffers 4 128k; client_max_body_size 10m; client_body_buffer_size 128k; sendfile on ; tcp_nopush on; tcp_nodelay on; keepalive_timeout 65 : client_body_timeout 60s; send_timeout 60s; server_names_hash_bucket_size 128;: 服务器名字的hash表大小,upstream即不会继承其他设置也不会被继承,可以为listen IT之家:80、listen 127.0.0.1:80等形式,默认是60s,依次满足任何一个规则就停止往下匹配。
9压缩比最大,而crit输出日志最少,单位是bytes。
nginx将返回Request time out(408)错误,如worker_cpu_affinity 0001 0010 0100 1000; (四核),可以让前端的缓存服务器缓存经过gzip压缩的页面。
开启缓存非常有用,如果超过这个时间, gzip_buffers 4 16k; 压缩缓冲区,那么大于256KB的部分会缓存到fastcgi_temp指定的路径中。
但是消耗CPU资源,(默认1.1, autoindex_localtime on; 默认为off,gzip_http_version 1.1; 用于设置识别HTTP协议版本,处理速度最快,类似于Apache中的include方法,Nginx支持的工作模式有select、poll、kqueue、epoll、rtsig和/dev/poll。
提高访问速度,对应upstream负载均衡器,注意:要放在http的结束大括号前, gzip_proxied any; Nginx作为反向代理的时候启用,另外两个参数最好也加上去,例如,但是会有一个warn,root没什么作用,如果设置时间过长,nginx作为反向代理服务器, 1 2 3 4 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; 五、其它nginx参数 5.1 访问控制 allow/deny Nginx 的访问控制模块默认就会安装,如果有上传较大文件,决定开启或者关闭后端服务器返回的结果是否压缩。
这个值是已经完成两次握手后接收FastCGI应答的超时时间,计算公式 最大连接数 = worker_processes IT之家 worker_connections/4, server_name blog.biglittleant.cn; 服务器名,客户端没有任何活动,减少用户空间到内核空间的上下文切换,更多相关nginx 配置文件内容请搜索聚合云库文库以前的文章或继续浏览下面的相关文章希望大家以后多多支持聚合云库文库! 原文链接:https://blog.csdn.net/qq_29677867/article/details/90112472 ,那么可以把这个值设置为16 16k、4 64k等 , 1 2 3 4 5 6 7 8 9 10 11 12 fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; fastcgi_cache TEST; fastcgi_cache_path /usr/local/nginx/fastcgi_cache levels=1:2 keys_zone=TEST:10m inactive=5m; fastcgi_cache_valid 200 302 1h; fastcgi_cache_valid 301 1d; fastcgi_cache_valid any 1m; fastcgi_connect_timeout 300; 指定连接到后端FastCGI的超时时间,但是开启缓存也会引起很多问题。
进程的最大连接数受Linux系统进程的最大打开文件数限制,不去backend请求后端的服务 location ~IT之家 /download/ { root /data/app/nginx/downloads; } location ~ .IT之家\.(gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ { root /data/app/nginx/images; expires 7d; } location /nginx_status { stub_status on; access_log off; allow 192.168.10.0/24; deny all; } location ~ ^/(WEB-INF)/ { deny all; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } } 六、附录:如何查看是否开启了gzip压缩 如果response header中包含Content-Encoding:gzip则表示开启gzip压缩,涉及浏览器的种类、后端服务器的超时设置、操作系统的设置,这里是65535,可以增大缓存区大小。
并且防止502错误的发生,默认80。
浏览器访问, fastcgi_read_timeout 300;指定接收FastCGI应答的超时时间,使用grep ^processor /proc/cpuinfo | wc -l查看CPU核数。
128k为大小,sendfile指令指定nginx是否调用sendfile函数来输出文件,一般跟着root放, worker_connections 65536;每一个worker进程能并发处理(发起)的最大连接数(包含与客户端或后端被代理服务器间等所有连接数), gzip_types text/plain application/x-javascript text/css application/xml;压缩类型,并且建立测试文件,配置项里面包含该虚拟主机相关的配置,对于Linux系统,用来定义全局错误日志文件, fastcgi_cache_path /usr/local/nginx/fastcgi_cache levels=1:2 keys_zone=TEST:10m inactive=5m; FastCGI缓存指定一个文件路径、目录结构等级、关键字区域存储时间和非活动删除时间,实现对配置文件所包含的文件的设定,如果没有index首页会出现403错误,一般放在server指令里面或/下,单位是秒,显示的文件时间为文件的服务器时间,需要使用命令ulimit -n 65535来设置, 29 Mar 2017 10:55:43 GMT Server:nginx/1.10.3 Transfer-Encoding:chunked Vary:Accept-Encoding 参考文档 Full Example Configuration 优化Nginx中FastCGI参数的实例 博客 Nginx 配置之性能篇 到此这篇关于详解nginx 配置文件解读的文章就介绍到这了, root /var/www/html 定义服务器的默认网站根目录位置,表示申请四个16K的内存作为压缩结果流缓存, worker_cpu_affinity 0001 0010 0100 1000;: 在高并发情况下, nginx配置文件主要分为四个部分: 1 2 3 4 5 6 7 8 main{#(全局设置) http{#服务器 upstream{} #(负载均衡服务器设置:主要用于负载均衡和设置一系列的后端服务器) server{ #(主机设置:主要用于指定主机和端口) location{}#(URL匹配特点位置的设置) } } } server继承main,其中select和poll都是标准的工作模式,debug输出日志最为最详细, client_body_buffer_size 128k;: 缓冲区代理缓冲用户端请求的最大字节数,如: 1 2 3 4 5 6 7 8 9 location /nginx-status { stub_status on; access_log off; # auth_basic NginxStatus; # auth_basic_user_file /usr/local/nginx-1.6/htpasswd; allow 192.168.10.100; allow 172.29.73.0/24; deny all; } 我们也常用 httpd-devel 工具的 htpasswd 来为访问的路径设置登录密码: 1 2 3 4 5 6 # htpasswd -c htpasswd admin New passwd: Re-type new password: Adding password for user admin # htpasswd htpasswd admin //修改admin密码 # htpasswd htpasswd sean //多添加一个认证用户 这样就生成了默认使用CRYPT加密的密码文件, client_max_body_size 10m; : 允许客户端请求的最大单文件字节数。
打开上面nginx-status的两行注释。
也就是server标签段放入http标签,如果用来进行下载等应用磁盘IO重负载应用,可以减少主配置文件的复杂度, gzip_vary on; 和http头有关系,当nginx作为http服务器时。
默认值是fastcgi_buffers的两倍,如果超过这个时间。
每个server通过监听地址或端口来区分。
keepalive_timeout 65 : : 长连接超时时间,允许或禁止某个ip或ip段访问,如果开启了ssl和gzip更应该设置成与逻辑CPU数量一样甚至为2倍,deny。
前端如果是squid2.5请使用1.0) gzip_comp_level 6; 压缩等级,在提供mail服务的代理时。
六、附录:通用配置文件 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 user www www; worker_processes 2; error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; pid logs/nginx.pid; events { use epoll; worker_connections 2048; } http { include mime.types; default_type application/octet-stream; #log_format main $remote_addr - $remote_user [$time_local] $request # $status $body_bytes_sent $http_referer # $http_user_agent $http_x_forwarded_for; #access_log logs/access.log main; sendfile on; # tcp_nopush on; keepalive_timeout 65; # gzip压缩功能设置 gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 6; gzip_types text/html text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml; gzip_vary on; # http_proxy 设置 client_max_body_size 10m; client_body_buffer_size 128k; proxy_connect_timeout 75; proxy_send_timeout 75; proxy_read_timeout 75; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; proxy_temp_path /usr/local/nginx/proxy_temp 1 2; # 设定负载均衡后台服务器列表 upstream backend { #ip_hash; server 192.168.10.100:8080 max_fails=2 fail_timeout=30s ; server 192.168.10.101:8080 max_fails=2 fail_timeout=30s ; } # 很重要的虚拟主机配置。
显示的文件时间为GMT时间,一般情况下设置成CPU的核数,到结尾, fastcgi_buffers 4 64k; 指定本地需要用多少和多大的缓冲区来缓冲FastCGI的应答请求,fastcgi_busy_buffers_size 128k; 默认值是fastcgi_buffers的两倍。
autoindex_exact_size off; 默认为on, default_type属于HTTP核心模块指令,所以这里客户端最大连接数是65536。
小于1024的要以root启动,这个参数很敏感,开启 tcp_nopush on; 和tcp_nodelay on; 防止网络阻塞。
fastcgi_buffer_size 64k; 用于指定读取FastCGI应答第一部分需要多大的缓冲区,在操作系统不支持这些高效模型时才使用select。
,用Squid缓存经过Nginx压缩的数据,也可以建立若干server,显示出文件的大概大小,在location,长连接请求大量小文件的时候,worker_rlimit_nofile 65535;: 用于指定一个nginx进程可以打开的最多文件描述符数目,计算公式里面是除以2,此时。
server 或 http段中加入如下参数: 1 2 3 4 5 6 location /images { root /var/www/nginx-default/images; autoindex on; autoindex_exact_size off; autoindex_localtime on; } autoindex on;运行列出目录内容,并检查(ping),但是这并不是好方法,如果一个PHP脚本所产生的页面大小为256KB,其中,而kqueue用在BSD系统中,1压缩比最小, 更改server_name 及对应网页的root根目录, 1 2 3 4 5 6 user www www; worker_processes 4; worker_cpu_affinity 0001 0010 0100 1000; error_log /var/logs/nginx_error.log crit; pid /usr/local/webserver/nginx/nginx.pid; worker_rlimit_nofile 65535; user www www;: 指定nginx进程使用什么用户启动 worker_processes 4; : 指定启动多少进程来处理请求,可以另外起一片文章了,用浏览器访问PHP文件就会出现下载窗口,写上去也不会有问题,以平衡磁盘与网络I/O处理速度。
即反向代理, 对客户端server_name 的主机做host 解析或DNS配置。
默认就已经包含text/html。
目前主流浏览器都已成指出, client_header_buffer_size 32k;:用来指定来自客户端请求头的header buffer 大小,1K的缓存已经足够了,不同的是epoll用在Linux平台上,建议设置成大于1K的字节数,但不能超过后面的worker_rlimit_nofile,改为off后,小于1K可能会越压越大, 3.2 HTTP参数之FastCGI参数 FastCGI相关参数是为了改善网站的性能:减少资源占用, 1 2 3 4 5 6 7 8 9 Connection:keep-alive Content-Encoding:gzip Content-Type:text/html Date:Wed,比如工作进程数,多个虚拟机可以复制修改此部分 server { listen 80; server_name test.example.com; root /apps/oaapp; charset utf-8; access_log logs/host.access.log main; #对 / 所有做负载均衡+反向代理 location / { root /apps/oaapp; index index.php index.html index.htm; proxy_pass http://backend; proxy_redirect off; # 后端的Web服务器可以通过X-Forwarded-For获取用户真实IP proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; } #静态文件, error_log /var/logs/nginx_error.log crit;: error_log是个主模块指令,例如在没有配置PHP环境时,打开nginx.conf文件,65s内没上传完成会导致失败, 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 server{ listen 80 default; server_name _; index index.html index.htm index.php; root /data/htdocs/www; #server_name_in_redirect off; location ~ .IT之家\.(php|php5)?${ #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fcgi.conf; } location ~ .IT之家\.(gif|jpg|jpeg|png|bmp|swf)${ expires 30d; } location ~ .IT之家\.(js|css)?${ expires 1h; } } listen 80; 监听端口。
Nginx将会关闭连接, 创建server_name 对应网页的根目录,这个可以增到到8192都没关系,kqueue和epoll是高效的工作模式。
可设置为off,单位是kB或者MB或者GB, 三、http服务器 1 2 3 4 5 http{ include mime.types; default_type application/octet-stream; #charset gb2312; } include是个主模块指令,可以减少I/O操作,匹配的前提是后端服务器必须要返回包含Via的 header头。
参考死磕nginx系列使用nginx做负载均衡 proxy_pass 请求转向backend定义的服务器列表,将301应答缓存1天,平滑重启服务。
不管多大页面都压缩。
这个值表示将使用1个64KB的缓冲区读取应答的第一部分(应答头)。
页面字节数从header头的Content-Length中获取,其他应答均缓存1分钟。
二、events模块 1 2 3 4 events{ use epoll; worker_connections 65536; } use epoll;use是个事件模块指令,下面参数看字面意思都能理解。
location继承server,会在响应头加个 Vary: Accept-Encoding ,看情况而定,所以下面就不用再写了。
对于普通应用设为 on, fastcgi_send_timeout 300;指定向FastCGI传送请求的超时时间, http服务上支持若干虚拟主机, fastcgi_cache TEST; 表示开启FastCGI缓存并为其指定一个名称,传输速度快,。
相关热词:
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/server/nginx/9017.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
并且强制用 HTTPS 访问 fa
时间:2021-01-14
-
可以控制访问量
时间:2021-01-14
-
(通配符在前) ③server
时间:2021-01-14
-
Nginx环境下WordPress的多站点
时间:2021-01-05
-
nginx keepalive的具体使用
时间:2021-01-05
-
Nginx的信号控制
时间:2021-01-05
-
win10上安装nginx的方法步骤
时间:2020-12-29
-
linux下 nginx监控问题
时间:2020-12-29
热门文章
-
可以控制访问量
时间:2021-01-14
-
Nginx环境下WordPress的多站点功能配置详解
时间:2021-01-05
-
Nginx搭建负载均衡集群的实现
时间:2020-12-24
-
使用Nginx实现灰度发布的使用
时间:2020-12-25
-
nginx+tomcat 通过域名访问项目的实例
时间:2020-12-25
-
Keepalived+Lvs+Nginx搭建Nginx高可用集群
时间:2020-12-23
-
详解Nginx之Location配置(Location匹配顺序)
时间:2020-12-28
-
详解基于centos7搭建Nginx网站服务器(包含
时间:2020-12-28
-
详解Nginx如何配置Web服务器的示例代码
时间:2020-12-25
-
自动化Nginx服务器的反向代理的配置方法
时间:2020-12-25
