nginx系列 2 概述
一. nginx功能概述
nginx 提供的基本功能服务归纳为:基本HTTP服务、高级HTTTP服务、邮件代理服务、TCP/UDP 代理服务等四大类。c语言开发
(1) Nginx提供基本HTTP服务,可以作为HTTP代理服务器和反向代理服务器,支持通过缓存加速访问,可以完成简单的负载均衡和容错,支持包过滤功能,支持SSL等。
(2) Nginx提供高级HTTP服务,可以进行自定义配置,支持虚拟主机,支持URL重定向,支持网络监控,支持流媒体传输等。
(3) Nginx 作为邮件代理服务器是最早开发这个产品的目的之一,它支持IMAP/POP3代理服务功能,支持内容SMTP代理服务功能。
1.1 基本HTTP服务
(1) 处理静态文件(如HTML静态网页及请求),处理索引文件以及支持自动索引。
(2) 打开并自行管理文件描述符缓存。
(3) 提供反向代理服务,并且可以使用缓存加速反向代理,同时完成简单负载均衡和容错。
(4) 提供远程FastCGI服务的缓存机制,加速访问,同时完成简单的负载均衡和容错。
(5) 使用Nginx的模块化特性提供过滤器功能,Nginx基本过滤器包括Gzip压缩、rgnges支持、chunked响应、XSLT、SSL以有图像缩放等。
(6) 支持HTTP下的安全套接层安全协议SSL。
1.2 高级http服务
(1) 支持基于名字和IP的虚拟主机设置。
(2) 支持http的Keep-alive模式和管线Pipelined模型连接。
(3) 支持重新加载配置以及在线升级时,无须中断中在处理的请求。
(4) 自定义访问日志格式、带缓存的日志写操作以及快速日志轮转和syslog日志记录。
(5) 提供http状态3xx~5xx错误代码重定向功能。
(6) 支持重写(Rewrite)模式扩展,使用正则表达式更改URL。
(7) 支持HTTP dav模块,为http webdav 提供put、DELETE、MKCOL、COPY、MOVE方法。
(8) 支持FLV流和MP4流传输。
(9) 支持网络监控,包括基于客户端IP地址和HTTP基本认证的访问控制、速度限制、来自同一地址的同时连接数或请求数限制等。
(10) 支持嵌入Perl语言。
(11) njs脚本语言。
1.3 邮件代理服务
(1) 支持使用外部HTTP认证服务器重定向 用户到IAMP/POP3后端,并支持IMAP认证方式和POP3认证方式。
(2) 支持使用外部HTTP认证服务器认证用户后 重定向连接到内部SMTP后端,并支持SMTP认证方式。
(3) 支持邮件代理服务下的安全套接层安全协议SSL。
(4) 支持纯文本通信协议的扩展协议starttls。
1.4 TCP/UDP代理服务器功能
(1) TCP/UDP的通用代理。
(2) SSL和TLS SNI 支持TCP。
(3) 负载均衡和容错。
(4) 基于客户端地址的访问控制。
(5) 根据客户端地址执行不同的功能。
(6) 限制来自同一个ip地址的同时连接数。
(7) 自定义访问日志格式、带缓存的日志写操作以及快速日志轮转和syslog日志记录。
(8) 基于IP的地理定位。
(9) njs脚本语言。
二.常用功能介绍
2.1 HTTP代理和反向代理
代理服务和反向代理是Nginx服务器作为Web服务器的主要功能之一,尤其是反向代理应用广泛。Nginx服务器转发来自前端的请求,性能稳定而且后端转发与业务配置相互分离,配置灵活。在后端转换请求完全不用关心网络环境如何,可以指定任意的ip和port或其他类型链接请求等。
通过正则表达式进行相关配置,可以实现根据不同的表达式,采取不同的转发策略,并且对后端异常判断则重新转向另一后端ip。
2.2 负载均衡
一般来说负载均衡是将大量前端并发访问或数据流量分担到多个后端网络节点上分别处理,这样可有效减少前端用户等待响应的时间。对于Nginx负载策略可分为两大类:内置策略和扩展策略。(1)内置策略:轮询、加权轮询、ip hash 三种;(2) 扩展策略主要通过第三方模块实现,种类丰富,常见有url hash、fair等。默认内置策略会被编译进Nginx内核,使用时只需要在Nginx服务器配置中设置相关参数即可。而扩展策略需要手动将第三方模块编码到Nginx内核。
2.3 Web缓存
Nginx服务器的Web缓存服务主要由proxy_cache和fastcgi_cache的相关指令集构成。其中proxy_cache主要用于在Nginx服务器提供反向代理服务时,对后端源服务器的返回内容进行URL缓存; fastcgi_cache主要用于对fastcgi的动态程序进行缓存。另外还有第三方模块的Web缓存功能。
Squid也是一款相当流行的开源代理服务器和Web缓存服务器。Ngnix服务器对多核CPU的调度比Squid更好,性能高于Squid。
三.优势
响应请求更快,
轻量级,
低代内存消耗:一般情况下10000个非活跃的http keep-alive连接在nginx上仅消耗2.5MB的内存,这是Nginx支持高并发连接的基础。
单机支持10万以上的并发连接
参考文献:
正向代理和反向代理:https://www.cnblogs.com/xdp-gacl/p/3706853.html
官方介绍:http://nginx.org/en/
Nginx高性能Web服务器详解