企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
1. 设置worker进程的用户,指的linux中的用户,会涉及到nginx操作目录或文件的一些权限,默认为nobody ``` user root; ``` 2. worker进程工作数设置,一般来说CPU有几个,就设置几个,或者设置为N-1也行,默认为1 ``` worker_processes 1; ``` 3. nginx 日志级别debug | info | notice | warn | error | crit | alert | emerg,错误级别从左到右越来越大 4. 设置nginx进程 pid ``` pid logs/nginx.pid; ``` 5. 设置工作模式 ``` events { # 默认使用epoll use epoll; # 每个worker允许连接的客户端最大连接数 worker_connections 1024; } ``` 6. http 是指令块,针对http网络传输的一些指令配置 ``` http { } ``` 7. include 引入外部配置,提高可读性,避免单个配置文件过大 ``` # 引入http mime类型 include mime.types; ``` 8. 设定日志格式,main为定义的格式名称,如此 access_log 就可以直接使用这个变量了 ![](https://img.kancloud.cn/12/b1/12b1b4d073684940947b68dc5c4d0aed_1234x963.png) 9. sendfile使用高效文件传输,提升传输性能。启用后才能使用tcp_nopush,是指当数据表累积一定大小后才发送,提高了效率。 ``` sendfile on; tcp_nopush on; ``` 10. keepalive_timeout设置客户端与服务端请求的超时时间,保证客户端多次请求的时候不会重复建立新的连接,节约资源损耗。 ``` #keepalive_timeout 0; keepalive_timeout 65; ``` 11. gzip启用压缩,html/js/css压缩后传输会更快 ``` gzip on; ``` 12. server 可以在http指令块中设置多个虚拟主机 * listen 监听端口 * server_name localhost、ip、域名 * location 请求路由映射,匹配拦截 * root 请求位置 * index 首页设置 ``` server { listen 88; server_name localhost; # https://tieba.baidu.com/index.html # 这个会匹配url中的URI部分, 也就是com 后面的 /index.html 部分 location / { root html; index index.html index.htm; } } ``` 13. upstream 指令参数 max_fails、fail_timeout max_fails:表示失败几次,则标记server已宕机,剔出上游服务。 fail_timeout:表示失败的重试时间。 ``` upstream tomcats { server 192.168.0.5:8080 weight=8; server 192.168.0.5:8081 weight=2 max_fails=2 fail_timeout=15s; server 192.168.0.6:8080 weight=2; server 192.168.0.6:8081 weight=1; } ``` 则代表在15秒内请求某一server失败达到2次后,则认为该server已经挂了或者宕机了,随后再过15秒,这15秒内不会有新的请求到达刚刚挂掉的节点上,而是会请求到正常运作的server,15秒后会再有新请求尝试连接挂掉的server,如果还是失败,重复上一过程,直到恢复。