一、Nginx主要作用:
- 反向代理
- 负载均衡
- HTTP服务器动静分离
- 正向代理
二、反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。简单来说就是真实的服务器不能直接被外部网络访问,所以需要一台代理服务器,而代理服务器能被外部网络访问的同时又跟真实服务器在同一个网络环境,当然也可能是同一台服务器,端口不同而已。
1 server { 2 listen 80; 3 server_name localhost; 4 client_max_body_size 1024M; 5 6 location / { 7 proxy_pass http://localhost:8080; 8 proxy_set_header Host $host:$server_port; 9 } 10 }
三、负载均衡
负载均衡也是Nginx常用的一个功能,负载均衡其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。简单而言就是当有2台或以上服务器时,根据规则随机的将请求分发到指定的服务器上处理,负载均衡配置一般都需要同时配置反向代理,通过反向代理跳转到负载均衡。而Nginx目前支持自带3种负载均衡策略,还有2种常用的第三方策略。
1、RR(默认):每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
1 upstream test { 2 server 127.0.0.1:8080; 3 server 192.168.10.10:8080; 4 } 5 server { 6 listen 81; 7 server_name localhost; 8 client_max_body_size 1024M; 9 10 location / { 11 proxy_pass http://test; 12 proxy_set_header Host $host:$server_port; 13 } 14 }
2、权重:指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
1 upstream test { 2 server 127.0.0.1:8080 weight=9; # 那么10次一般只会有1次会访问到8081,而有9次会访问到8080 3 server 192.168.10.10:8081 weight=1; 4 } 5 server { 6 listen 81; 7 server_name localhost; 8 client_max_body_size 1024M; 9 10 location / { 11 proxy_pass http://test; 12 proxy_set_header Host $host:$server_port; 13 }
3、ip_hash:
当我们的程序不是无状态的时候(采用了session保存数据),这时候就有一个很大的很问题了,比如把登录信息保存到了session中,那么跳转到另外一台服务器的时候就需要重新登录了,所以很多时候我们需要一个客户只访问一个服务器,那么就需要用iphash了,iphash的每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题.
1 upstream test { 2 ip_hash: 3 server 127.0.0.1:8080; 4 server 127.0.0.1:8081; 5 } 6 server { 7 listen 81; 8 server_name localhost; 9 client_max_body_size 1024M; 10 11 location / { 12 proxy_pass http://test; 13 proxy_set_header Host $host:$server_port; 14 } 15 }
4、fair(第三方):按后端服务器的响应时间来分配请求,响应时间短的优先分配。
1 upstream test { 2 fair; 3 server localhost:8080; 4 server localhost:8081; 5 }
5、url_hash
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。 在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法.
1 upstream backend { 2 hash $request_uri; 3 hash_method crc32; 4 server 127.0.0.1:8080; 5 server 127.0.0.1:8081; 6 }
四、HTTP服务器(动静分离)
Nginx本身也是一个静态资源的服务器,当只有静态资源的时候,就可以使用Nginx来做服务器,同时也可以通过Nginx来实现动静分离,动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路。
1 upstream test{ 2 server localhost:8080; 3 server localhost:8081; 4 } 5 6 server { 7 listen 80; 8 server_name localhost; 9 location / { 10 root e:\wwwroot; 11 index index.html; 12 } 13 # 所有静态请求都由nginx处理,存放目录为html 14 location ~ \.(gif|jpg|jpeg|png|bmp|swf|css|js)$ { 15 root e:\wwwroot; 16 } 17 # 所有动态请求都转发给tomcat处理 18 location ~ \.(jsp|do)$ { 19 proxy_pass http://test; 20 } 21 error_page 500 502 503 504 /50x.html; 22 location = /50x.html { 23 root e:\wwwroot; 24 } 25 }
五、热启动:Nginx 是支持热启动的,也就是说当我们修改配置文件后,不用关闭 Nginx,就可以实现让配置生效。
Nginx 重新读取配置的命令是:nginx -s reload
Windows 是:nginx.exe -s reload