nginx实现负载均衡
一、Nginx
什么是Nginx?
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler使用。其特点是占有内存少,并发能力强,中国大陆使用nginx网站用户有:百度、新浪、网易、腾讯等。
优点:
1、可运行linux,并有windows 移植版
2、在高并发情况下,Nginx 可支持高达50000个并发连接数的响应。
Nginx如何实现负载均衡?
1、Nginx反向代理
Nginx利用自身反向代理功能,在conf配置文件中添加反向代理地址,以代理服务器的身份接受客户端发送过来的请求,然后将请求转发给内部网络上的应用服务器,并将从服务器上得到的结果返回给客户端,此时代理服务器对外就表现为一个服务器,不过它只负责转发请求,不负责处理。
2、Nginx转发策略
Nginx转发请求可按照调度规则通过轮询、ip哈希、URL哈希、权重等多种方式对应用服务器做负载均衡,同时还支持后端服务器的健康检查,也就是上面讲的故障移除和恢复添加功能。
nginx 的 upstream目前支持的分配算法:
1)、轮询(默认) 每个请求按时间顺序逐一分配到不同的应用服务器,如果应用服务器down掉,能自动剔除。
2)、权重 通过配置权重,指定轮询几率,权重和访问比率成正比,用于应用服务器性能不均的情况。
3)、ip_哈希算法 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个应用服务器,可以解决session共享的问题。
案例
步骤一:准备两个Tomcat 一个端口为8081,另一个端口为8082;
步骤二:配置nginx.conf文件
步骤三:启动Tomcat和nginx
启动Tomcat:这里需要启动两次Tomcat,一次端口为8082,一次端口为8081
进入Tomcat文件下的bin目录
使用【./startup.sh】 命令启动
启动后可使用【ps -ef | grep tomcat 】命令查看当前Tomcat的进程
启动nginx:
进入nginx文件下的sbin目录
使用【./nginx】命令启动nginx
使用【ps -ef | grep nginx】命令查看当前nginx进程
实现效果:默认的负载均衡采用轮询机制的,每个请求按时间顺序逐一分配到不同的后端服务器上,如果后端服务器down掉,能自动剔除;按照http://www.b.com访问页面。
nginx实现负载均衡的方式
1.轮询
每个请求按时间顺序逐一分配到不同的后端服务器上,如果后端服务器down掉,能自动剔除;
2.权重(weight)
weight代表权,重默认为1,权重越高被分配的客户端越多;
指定轮询几率,权重和访问比率成正比,用于后端服务性能不均的请求下。
3.ip_hash
每个请求按访问IP的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题;
4.第三方(fair)
按后端服务器的响应时间来分配请求,响应时间短的优先分配;