1、网络IO事件模型:use epoll; 在/etc/nginx/ngin.conf添加 events { worker_connections 1024; use epoll; }

2、进程数量及 CPU绑定

#将work process绑定到特定cpu上,避免进程在cpu间切换的开销 worker_cpu_affinity 0001 0010 0100 1000

#4内核8进程时的设置方法:worker_cpu_affinity 00000001 00000010 00000100 10000000

3、隐藏软件名及版本信息:http{ server_tokens off;}

4、日志:

日志切割\轮询 不记录不需要的日志:

location /nginx-status { stub_status on; access_log off; }

访问量

PV:点击量

UV:客户量

访问日志的权限设置:

chown -R root.root /app/logs

chmod -R 600 /app/logs

5、NGINX 防止DOS/DDOS攻击

限制用户并发连接数:

http{ limit_conn_zone $binary_remote_addr zone=perip_conn:10m; }

ngx_http_limit_conn_module:调用limit_conn模块 $binary_remote_addr: 二进制远程地址 zone=perip_conn:10m:定义zone名字叫perip_conn,并为这个zone分配10M内存,用来存储会话(二进制远程地址),1m内存可以保存16000会话。

location{ limit_conn perip_conn 1;}

限制用户连接速率:

http{limit_req_zone $binary_remote_addr zone=reqrate:20m rate=10r/s; }

limit_req_zone:调用limit_req模块 rate=10r/s:频率为每秒10个请求

location{ limit_req zone=reqrate burst=5; }

burst=5:允许超过频率限制的请求数不多于5个,假设1、2、3、4秒请求为每秒9个,那么第5秒内请求15个是允许的,如果第一秒内请求15个,会将5个请求放到第二秒,第二秒内超过10的请求直接503,类似多秒内平均速率限制。