(1)使用nginx的原因
项目刚刚上线的时候,并发量小,用户使用的少,所以在低并发的情况下,一个jar包启动应用就够了,然后内部tomcat返回内容给用户。
但是慢慢的,使用我们平台的用户越来越多了,并发量慢慢增大了,这时候一台服务器满足不了我们的需求了。
于是我们横向扩展,增加了多个服务器。这个时候,同个服务启动在不同的服务器上,每个Tomcat服务器是负载均衡的一部分,以处理来自服务器1的请求。服务器1就是代理服务器。用户要访问,通过代理服务器访问服务,代理服务器来帮我们转发和处理请求。
我们希望这个代理服务器可以帮助我们接收用户的请求,然后将用户的请求按照规则帮我们转发到不同的服务器节点之上。这个过程用户是无感知的,用户并不知道是哪个服务器返回的结果,我们还希望它可以按照服务器的性能提供不同的权重选择。保证最佳体验!所以我们使用了nginx。
(2)什么是nginx
nginx是一个高性能的HTTP和反向代理web服务器。(HTTP服务器是专门用来响应客户端HTTP请求的服务器。HTTP是用于传输超文本(如 HTML 文档)的应用层协议)
nginx的特点是占有内存少,并发能力强。事实上,nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
nginx是一个安装简单、配置文件简洁、Bug很少的服务。nginx启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。还能够在不间断服务的情况下进行软件版本的升级。
nginx代码完全用C语言写成。官方测试数据表明能够支持高达50000个并发连接数的响应。
(3)nginx作用(代理服务器,接收处理Http的请求;代理服务器,反向代理)
① 正向代理
② 反向代理
③ 负载均衡策略
nginx提供的负载均衡策略有2种:内置策略和扩展策略。内置策略为轮询,加权轮询,Ip hash。扩展策略,就天马行空,只有你想不到的没有它做不到的。
1. 轮询
2. 加权轮询(理解:6个请求,1个打到服务器1,2个打到服务器2,3个打到服务器3)
3. ip hash
Ip hash对客户端请求的ip进行hash操作,然后根据hash结果将同一个客户端ip的请求分发给同一台服务器进行处理,可以解决session不共享的问题。
(4)动静分离
动静分离,在软件开发中,有些请求是需要后台处理的,有些请求是不需要经过后台处理的。如css、html、jpg、js等文件,这些不需要经过后台处理的文件,是静态文件。动态网站里的动态网页,是动态文件。根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作。提高资源响应的速度。