24资源网

24资源分享网,分享资源,收集整理资源,有态度的分享资源网

Nginx基础入门001

avatar 小四 2023-01-25 22:00 34次浏览 0 条评论 服务器

人生舞台的大幕随时都可能拉开,关键是你愿意表演,还是选取躲避。

Nginx源码学习[1],下一篇:ailx10:Nginx基础入门002

ailx10
1246 次咨询
4.9
网络安全优秀回答者
网络安全硕士
去咨询
Nginx默认安装位置:/usr/local/nginx/ Nginx默认二进制位置:/usr/local/nginx/sbin/ Nginx默认配置文件位置:/usr/local/nginx/conf/ Nginx启动:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf Nginx停止:/usr/local/nginx/sbin/nginx -s stop 优雅的停止:/usr/local/nginx/sbin/nginx -s quit重新加载配置:/usr/local/nginx/sbin/nginx -s reload

Nginx和Apache最大的不同:

Apache每个进程在一个时刻只处理一个请求,并发数高的时候,需要创建大量的进程,进程切换会带来无畏的系统资源消耗。

Nginx每个worker进程都可以同时处理多个请求,当进程数和CPU核数相等时,进程间切换的代价是最小的。

块配置项2部分组成:

块配置项名字大括号里面的内容

配置项由对应的模块解析!

行首是配置项名字,紧跟其后是配置项值,多个值用空格隔开,用#注释。

配置项的单位:

千字节兆字节毫秒秒分小时天周月年kMmssmhdwMy千字节兆字节毫秒秒分小时天周月年\begin{array}{c|c} \text{k} & \text{M} & \text{ms} & \text{s} & \text{m} & \text{h} & \text{d} & \text{w} & \text{M} & \text{y} & \\ \hline 千字节& 兆字节 & 毫秒& 秒& 分& 小时& 天& 周& 月& 年 \\ \end{array}\\

Nginx的基本配置项:

用于调试、定位问题的配置项正常运行的必备配置项优化性能的配置项events{}事件类配置项

1.用于调试进程和定位问题的配置项

1.1 是否以守护进程方式运行Nginx

语法:daemon on | off; (默认是on)

1.2 是否以master/worker方式工作

语法:master_process on | off; (默认on)

1.3 error日志的配置

语法:error_log /path/file level; (默认 logs/error.log error;)

日志级别:debug、info、notice、warn、error、crit、alert、emerg

不想记录日志的话,path/file设置为/dev/null

1.4 是否处理几个特殊的调试点

语法:debug_points [stop | abort]

一般不会使用这个配置项,这是Nginx自己设置的调试点

1.5 仅对指定的客户端输出debug级别的日志

语法:debug_connection [IP | CIDR]

events { debug_connection 127.0.0.1; debug_connection 192.168.0.0/24; }

凡是输出debug日志的配置项,都需要在configure阶段加入–with-debug

1.6 限制coredump核心转储文件的大小

语法:work_rlimit_core size;

core dumps文件,面试经常问

1.7 指定coredump文件生成目录

语法:working_directory path;

2 正常运行的配置项

2.1 定义环境变量

语法:env VAR | VAR=VALUE

直接设置操作系统的环境变量

2.2 嵌入其他配置文件

语法:include /path/file;

include配置项可以将其他配置文件嵌入到当前的nginx.conf文件中,参数可以是相对路径,也可以是绝对路径(建议写绝对路径)。

2.3 pid文件的路径

语法:pid path/file;(默认:pid logs/nginx.pid;)

保存master进程ID的pid文件存放路径

2.4 Nginx worker进程运行的用户及用户组

语法:user username [groupname];(默认:user nobody nobody;)

2.5 指定Nginx worker进程可以打开的最大句柄描述符个数

语法:worker_rlimit_nofile limit;

2.6 限制信号队列

语法:worker_rlimit_sigpending limit;

设置每个用户发往Nginx的信号队列的大小。

3 优化性能的配置项

3.1 Nginx worker进程个数

语法:worker_process number;(默认:1)

3.2 绑定Nginx worker进程到指定的CPU内核

语法:woker_cpu_affinity cpumask

配置与CPU内核数相等的worker进程

3.3 SSL硬件加速

语法:ssl_engine device;

3.4 系统调用gettimeofday的执行频率

语法:timer_resolution t;

默认情况,每次内核的事件调用(epoll、select、poll、kqueue)返回时,都会执行一次gettimeofday,实际用内核的时钟来更新Nginx中的缓存时钟。当需要降低gettimeofday的调用频率时,可以使用time_resolution配置。

3.5 Nginx worker进程优先级设置

语法:worker_priority nice;(默认:0)

nice值时进程的静态优先级,-20是最高优先级,+19是最低优先级。

4 事件类配置项

4.1 是否打开accept锁

语法:accept_mutex [on | off](默认:on)

accept_mutex是Nginx的负载均衡锁,这把锁可以让多个worker进程轮流地、序列化地与新的客户端建立TCP连接。当某一个worker进程建立的连接数量达到worker_connections配置的最大连接数的7/8时,会大大地减小该worker进程试图建立新TCP连接的机会,以此实现所有worker进程之上处理的客户端请求数尽量接近。

4.2 lock文件的路径

语法:lock_file path/file;(默认:logs/nginx.lock)

4.3 使用accept锁后到真正建立连接之间的延迟时间

语法:accept_mutex_delay Nms;(默认:500ms)

如果一个work进程试图取accept锁而没有取到,它至少要等500ms的时间间隔后才能再次试图取锁。

4.4 批量建立新连接

语法:multi_accept [on | off];(默认:off)

当事件模型通知有新连接时,尽可能地对本次调度中客户端发起的所有TCP请求都建立连接。

4.5 选择事件模型

语法:use [kqueue | sting | epoll | select | poll | eventport];

4.6 每个worker的最大连接数

语法:worker_connections number;

参考

^reading-code-of-nginx-1.9.2 https://github.com/y123456yz/reading-code-of-nginx-1.9.2

               
发表评论