[备忘录]-Nginx配置文件详解
2017-11-08 20:53
253 查看
# 全局设置 #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数。 worker_processes 2; #全局错误日志定义类型,[ debug | info | notice | warn | error | crit ] # 在高并发情况下,通过设置cpu粘性来降低由于多CPU核切换造成的寄存器等现场重建带来的性能损耗。 worker_cpu_affinity 01 10; error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #进程pid文件 pid logs/nginx.pid; #指定一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀,所以最好与ulimit -n 的值保持一致。 worker_rlimit_nofile 65535; # 事件配置 events { # 参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ]; # epoll模型是Linux 2.6以上版本内核中的高性能网络I/O模型,linux建议epoll use epoll; # 单个进程最大连接数(最大连接数=连接数*进程数) # 根据硬件调整,和前面工作进程配合起来用,尽量大,但是别把cpu跑到100%就行。 worker_connections 2048; } # http参数配置 http { # 文件扩展名与文件类型映射表 include mime.types; #默认文件类型 default_type application/octet-stream; #默认编码 #charset utf-8; #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指令指定nginx是否调用sendfile函数来输出文件,减少用户空间到内核空间的上下文切换 sendfile on; # tcp_nopush on; # 长连接超时时间,单位是秒 keepalive_timeout 60; # gzip压缩功能设置 # 开启gzip压缩输出,减少网络传输 gzip on; # 设置允许压缩的页面最小字节数,页面字节数从header头得content-length中进行获取。默认值是20。 gzip_min_length 1k; # 设置系统获取几个单位的缓存用于存储gzip的压缩结果数据流。4 16k代表以16k为单位,安装原始数据大小以16k为单位的4倍申请内存。 gzip_buffers 4 16k; # 用于识别 http 协议的版本,早期的浏览器不支持 Gzip 压缩,用户就会看到乱码,所以为了支持前期版本加上了这个选项,如果你用了 Nginx 的反向代理并期望也启用 Gzip 压缩的话,由于末端通信是 http/1.0,故请设置为 1.0。 gzip_http_version 1.0; # gzip压缩比,1压缩比最小处理速度最快,9压缩比最大但处理速度最慢(传输快但比较消耗cpu) gzip_comp_level 3; # 匹配mime类型进行压缩,无论是否指定,”text/html”类型总是会被压缩的。 gzip_types text/html text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml; # 和http头有关系,会在响应头加个 Vary: Accept-Encoding ,可以让前端的缓存服务器缓存经过gzip压缩的页面,例如,用Squid缓存经过Nginx压缩的数据。 gzip_vary on; # http_proxy 设置 # 允许客户端请求的最大单文件字节数。用于上传 client_max_body_size 10m; # 缓冲区代理缓冲用户端请求的最大字节数 client_body_buffer_size 128k; # nginx跟后端服务器连接超时时间(代理连接超时) proxy_connect_timeout 75; proxy_send_timeout 75; # 连接成功后,与后端服务器两个成功的响应操作之间超时时间(代理接收超时) proxy_read_timeout 75; # 设置代理服务器(nginx)从后端realserver读取并保存用户头信息的缓冲区大小,默认与proxy_buffers大小相同,其实可以将这个指令值设的小一点 proxy_buffer_size 4k; # proxy_buffers缓冲区,nginx针对单个连接缓存来自后端realserver的响应,网页平均在32k以下的话,这样设置 proxy_buffers 4 32k; # 高负荷下缓冲大小(proxy_buffers*2) proxy_busy_buffers_size 64k; # 当 proxy_buffers 放不下后端服务器的响应内容时,会将一部分保存到硬盘的临时文件中,这个值用来设置最大临时文件大小,默认1024M,它与 proxy_cache 没有关系。大于这个值,将从upstream服务器传回。设置为0禁用。 proxy_temp_file_write_size 64k; proxy_temp_path /usr/local/nginx/proxy_temp 1 2; # 设定负载均衡后台服务器列表 # upstream(上游服务器设置,主要为反向代理、负载均衡相关配置) 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 ; } # 很重要的虚拟主机配置 # server(主机设置) server { # 端口 listen 80; # 服务器名,可以有多个,用空格隔开 server_name itoatest.example.com; # 定义服务器的默认网站根目录位置。 # root /apps/oaapp; charset utf-8; access_log logs/host.access.log main; # location(URL匹配特定位置后的设置) # 对 / 所有做负载均衡+反向代理 location / { # 定义服务器的默认网站根目录位置。 root /apps/oaapp; # 定义路径下默认访问的文件名,一般跟着root放 index index.jsp index.html index.htm; # 请求转向backend定义的服务器列表,即反向代理,对应upstream负载均衡器。 proxy_pass http://backend; proxy_redirect off; #以下是一些反向代理的配置,可选。 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP 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; } #设定查看Nginx状态的地址 location /status { stub_status on; access_log on; auth_basic "status"; auth_basic_user_file confpasswd; #htpasswd文件的内容可以用apache提供的htpasswd工具来产生。 } #图片缓存时间设置 location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$ { expires 10d; } #JS和CSS缓存时间设置 location ~ .*.(js|css)?$ { expires 1h; } #本地动静分离反向代理配置 #所有jsp的页面均交由tomcat或resin处理 location ~ .(jsp|jspx|do)?$ { 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_pass http://127.0.0.1:8080; } #所有静态文件由nginx直接读取不经过tomcat或resin location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt| pdf|xls|mp3|wma)$ { expires 15d; } #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; } } ## 其它虚拟主机,server 指令开始 }
相关文章推荐
- Centos6.6搭建nginx服务及配置文件详解
- nginx学习笔记7 nginx配置文件详解
- Nginx配置文件nginx.conf中文详解
- Nginx配置文件详解
- Nginx安装及配置文件nginx.conf详解
- Nginx配置文件详解
- Nginx配置文件nginx.conf中文详解
- Nginx配置文件(nginx.conf)配置详解(二)
- nginx 配置文件详解
- Nginx配置文件中文注释详解(参考)
- Nginx 服务器安装及配置文件详解
- Nginx安装及配置文件nginx.conf详解
- Nginx配置文件优化详解
- Nginx服务器配置文件nginx.conf实例详解
- Nginx配置文件nginx.conf中文详解
- Nginx 服务器安装及配置文件详解
- 比较完整的Nginx配置文件nginx.conf常用参数中文详解
- nginx配置文件详解
- Nginx配置文件nginx.conf中文详解(总结)
- Nginx的配置文件nginx.conf配置详解