注:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。

nginx的强大之处不必要我细说,当初第一次接触nginx的时候就发现了它的强大之处,并且自我觉得非常有必要出一篇记录nginx的各个功能及坑点。

欢迎大家对nginx感兴趣的朋友们来一起学习与及时提出错误及误点。有问题的可以在评论区@我。

一:nginx配置文件详解

nginx配置文件不算多,但是几乎每一层都有它精确的意思,所以要学习好nginx,必须先了解它的配置文件,接下来就解释一些nginx常用的一些配置文件的含义

  1. #定义Nginx运行的用户和用户组
  2. user www www;

  3. #启动进程,通常设置成和cpu的数量相等
  4. worker_processes 8;

  1. #为每个进程分配cpu,上例中将8个进程分配到8个cpu,当然可以写多个,或者将一个进程分配到多个cpu。
  1. worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;

  1. #这个指令是指当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打
  2. #开文件数(ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀
  3. #,所以最好与ulimit -n的值保持一致。

    worker_rlimit_nofile 102400;
  1. #全局错误日志及PID文件
  2. error_log /usr/local/nginx/logs/error.log;
  3. #错误日志定义等级,[ debug | info | notice | warn | error | crit ]
  4. pid /usr/local/nginx/nginx.pid;
  5. #一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀.
  6. #所以建议与ulimit -n的值保持一致。
  7. worker_rlimit_nofile 65535;
  8. #工作模式及连接数上限
  9. events {
  10. use epoll; #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
  11. worker_connections 102400; #单个后台worker process进程的最大并发链接数 (最大连接数=连接数*进程数)
  12. multi_accept on; #尽可能多的接受请求
  13. }
  14. #设定http服务器,利用它的反向代理功能提供负载均衡支持
  15. http {
  16. #设定mime类型,类型由mime.type文件定义
  17. include mime.types;
  18. default_type application/octet-stream;
  19. #设定日志格式
  20. access_log /usr/local/nginx/log/nginx/access.log;
  21. sendfile on;
  22. #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用必须设为 on
  23. #如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
  24. #autoindex on; #开启目录列表访问,合适下载服务器,默认关闭。
  25. tcp_nopush on; #防止网络阻塞
  26. keepalive_timeout 60;
  27. #keepalive超时时间,客户端到服务器端的连接持续有效时间,当出现对服务器的后,继请求时,keepalive-timeout功能可避免建立或重新建立连接。
  28. tcp_nodelay on; #提高数据的实时响应性
  29. #开启gzip压缩
  30. gzip on;
  31. gzip_min_length 1k;
  32. gzip_buffers 4 16k;
  33. gzip_http_version 1.1;
  34. gzip_comp_level 2; #压缩级别大小,最大为9,值越小,压缩后比例越小,CPU处理更快。
  35. #值越大,消耗CPU比较高。
  36. gzip_types text/plain application/x-javascript text/css application/xml;
  37. gzip_vary on;
  38. client_max_body_size 10m; #允许客户端请求的最大单文件字节数
  39. client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数,
  40. proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时)
  41. proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时)
  42. proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)
  43. proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
  44. proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
  45. proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2
  46. #设定请求缓冲
  47. large_client_header_buffers 4 4k;
  48. client_header_buffer_size 4k;
  49. #客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求的头部大小不会超过1k
  50. #不过由于一般系统分页都要大于1k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。
  51. open_file_cache max=102400 inactive=20s;
  52. #这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存。
  53. open_file_cache_valid 30s;
  54. #这个是指多长时间检查一次缓存的有效信息。
  55. open_file_cache_min_uses 1;
  56. #open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的,如上例,如果有一个文件在inactive
  57. #包含其它配置文件,如自定义的虚拟主机
  58. include vhosts.conf;

以上为简单的nginx配置详解,根据项目需求来配置,并非所有都需要,视情况而定。

二:nginx配置文件详解(这里主要为了达到某个项目需求及作用而配置)

  1. #这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,test为负载均衡名称,可以任意指定
  2. #但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。weight配置权重,在fail_timeout内检查max_fails次数,失败则剔除均衡。(即可理解为负载均衡的安全检查,后面还会演示另种方法)
  3. upstream test {
  4. server 127.0.0.1:8080 weight=1 max_fails=2 fail_timeout=30s;
  5. server 127.0.0.1:8081 weight=1 max_fails=2 fail_timeout=30s;
  6. }
  7. #虚拟主机配置
  8. server {
  9. #侦听80端口
  10. listen 80;
  11. #定义使用www.maxiaotian.com访问,前提为此域名必须解析了此主机IP。
  12. server_name www.maxiaotian.com;
  13. #设定本虚拟主机的访问日志
  14. access_log logs/access.log main;
  15. root /data/webapps/maxt; #定义服务器的默认网站根目录位置
  16. index index.php index.html index.htm; #定义首页索引文件的名称
  17. #默认请求
  18. location ~ /{
  19. root /data/www/maxt; #定义服务器的默认网站根目录位置
  20. index index.php index.html index.htm; #定义首页索引文件的名称
  21. #以下是一些反向代理的配置.
  22. proxy_next_upstream http_502 http_504 error timeout invalid_header;
  23. #如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。
  24. proxy_redirect off;
  25. #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
  26. proxy_set_header Host $host;
  27. proxy_set_header X-Real-IP $remote_addr;
  28. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  29. proxy_pass http://tdt_wugk; #请求转向后端定义的均衡模块
  30. }
  31. # 定义错误提示页面
  32. error_page 500 502 503 504 /50x.html;
  33. location = /50x.html {
  34. root html;
  35. }
  36. #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
  37. location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
  38. {
  39. root /data/www/maxt;
  40. #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力。
  41. expires 3d;
  42. }
  43. #PHP脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
  44. location ~ \.php$ {
  45. root /root;
  46. fastcgi_pass 127.0.0.1:9000;
  47. fastcgi_index index.php;
  48. fastcgi_param SCRIPT_FILENAME /data/www/wugk$fastcgi_script_name;
  49. include fastcgi_params;
  50. }
  51. #设定查看Nginx状态的地址
  52. location /NginxStatus {
  53. stub_status on;
  54. }
  55. }
  56. }

大概的配置文件解释就到此了,对于一些初期接触nginx的同学肯定会觉得蒙蒙的,其实很正常,很多配置可能需要结合实践项目去认识会更快,更能理解。所以后面nginx系列文档中,我也会编写一些结合项目实践的一些配置,希望能帮到大家!

版权声明:本文为maxtgood原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/maxtgood/p/9598333.html