Nginx的诞生
俄罗斯工程师lgor Sysoev为Rambler Media工作期间使用C语言开发了Nginx。Nginx有以下特点:
- 基于事件的驱动架构,使其可以支持数以百万级别的TCP连接
- 高度的模块化和自由软件许可证使得第三方模块层出不穷
- Nginx是一个跨平台的服务器,可运行在Linux,Windows,FreeBSD,Solaris、AIX、Mac OS等操作系统上
- 设计优秀,性能稳定
因为上述种种优点而使得Nginx大受欢迎!
Nginx的使用场景
什么是Nginx?
Nginx是一款自由、开源、高性能的HTTP服务器和反向代理服务器,同时也是一个IMAP、POP3、SMTP代理服务器。Nginx不仅可以作为HTTP服务器发布网站,也可以作为反向代理服务器实现负载均衡。
正向代理
正向代理,代理的是客户端,代客户端发出请求。简而言之就是一个位于客户端和原始服务器之间的服务器,客户端向代理发送一个请求并指定原始服务器,然后代理向原始服务器转交请求并将返回数据转发给客户端。客户端需要进行一些特别的设置才能使用正向代理。
使用场景:
- 访问原本无法访问的资源,如外网
- 做缓存,加速访问资源
- 对客户端访问授权认证
- 记录用户访问记录,对外隐藏用户信息
反向代理
反向代理,代理的是服务端,代服务端接收请求。简而言之就是多个客户端给服务端发送请求,Nginx收到之后按照一定规则分发给后端业务处理服务器进行处理。此时请求的客户端是明确的,但是请求具体由哪台服务器处理并不明确,Nginx扮演的是一个反向代理角色。反向代理主要用于服务端集群分布式部署的情况下,反向代理隐藏了服务器的信息。
使用场景:
- 保证内网安全,通常将反向代理作为公网访问地址,Web服务器则作为内网
- 负载均衡,通过反向代理服务器来优化网站负载
正向代理和反向代理的区别
在正向代理中,代理服务器和客户端同属于一个LAN,客户端信息被隐藏。
在反向代理中,代理服务器和客户端同属于一个LAN,服务端信息被隐藏。
负载均衡
请求数量按照一定的规则进行分发到不同的服务器处理的规则,就是一种负载均衡规则,因此将服务器接收到的请求按照规则分发的过程,称为负载均衡。
负载均衡实际中分为硬件负载均衡和软件负载均衡两种,硬件负载均衡也称为硬负载,如F5负载均衡,相对造价昂贵成本较高,但是数据的稳定性安全性等更好。软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制。
Nginx支持的负载均衡算法:
- weight轮询(默认)
接收到的请求按照权重分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,Nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率,权重数据越大,被分配到请求的几率越大。 - ip_hash(常用)
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,这在一定程度上解决了集群部署环境下session共享的问题。 - fair
智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少,这种算法结合了前两者的优点。Nginx默认不支持fair算法,如果要使用这种调度算法,必须安装upstream_fair模块。 - url_hash
按照访问的url的hash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在Nginx作为静态服务器的情况下提高缓存效率。Nginx默认不支持这种调度算法,要使用的话必须安装Nginx的hash软件包。