一、nginx是什么?
nginx是一个开源且高性能、可靠的HTTP中间件和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务
nginx高效、高性能的原因:
采用了IO多路复用epoll模型,epoll是Linux目前大规模网络并发程序开发的首选模型。在绝大多数情况下性能远超select和poll。epoll的底层实现为红黑树。
IO多路复用是Unix五种IO模型的一种。
Unix五种IO模型:
- blocking IO - 阻塞IO
- nonblocking IO - 非阻塞IO
- IO multiplexing - IO多路复用
- signal driven IO - 信号驱动IO
- asynchronous IO - 异步IO
I/O多路复用(multiplexing)的本质是通过一种机制(系统内核缓冲I/O数据),让单个进程可以监视多个文件描述符,一旦某个描述符就绪(一般是读就绪或写就绪),能够通知程序进行相应的读写操作,select、poll 和 epoll 都是 Linux API 提供的 IO 复用方式。
**nginx的CPU亲和:**是一种把CPU核心和nginx工作进程绑定方式,把每个worker进程固定在一个cpu上执行,减少切换cpu的cache miss,获得更好的性能。
linux为了解决对读文件产生的从应用空间到内核空间复制数据产生的效率影响引进了零拷贝,零拷贝请参考https://blog.csdn.net/weixin_42096901/article/details/103017044。
web服务器可以通过调整自身的配置来决定是否利用 sendfile这个系统调用,nginx通过使用sendfile指令来控制是不是用linux提供的零拷贝功能,当把nginx作为一个静态资源服务器时,开启SENDFILE 配置项能大大提高 Nginx 的性能。