zoukankan      html  css  js  c++  java
  • Nginx 负载均衡搭建

    配置文件Nginx/conf/nginx.conf

    什么是负载均衡呢? 

    由于目前现有网络的各个核心部分随着业务量的提高,访问量和数据流量的快速增长,其处理能力和计算强度也相应地增大,使得单一的服务器设备根本无法承担。在此情况下,如果扔掉现有设备去做大量的硬件升级,这样将造成现有资源的浪费,而且如果再面临下一次业务量的提升时,这又将导致再一次硬件升级的高额成本投入,甚至性能再卓越的设备也不能满足当前业务量增长的需求。 
    针对此情况而衍生出来的一种廉价有效透明的方法以扩展现有网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性的技术就是负载均衡(Load Balance)。


    负载均衡的种类

    1)一种是通过硬件来进行解决,常见的硬件有NetScaler、F5、Radware和Array等商用的负载均衡器,但是它们是比较昂贵的
    2)一种是通过软件来进行解决的,常见的软件有LVS、Nginx、apache等,它们是基于Linux系统并且开源的负载均衡策略.

    负载均衡的功能:
    转发
    故障移除
    恢复添加
    高可用 Ha

    我们想要使用Nginx那么就必须满足上面的四个条件.
    我们配置负载均衡的目的是在于当用户访问我们的服务器的时候, 首先会通过 Nginx服务器来决定转发到哪个Tomcat服务器上去给用户提供服务, 当然这个概率是我们通过权重来配置的. 经过Nginx指派之后, 我们就可以处理高并发的访问了, 这里就能达到负载均衡的目的.

    创建两台Nginx服务器
    由于自己在自己电脑上搭建, 所以 现在只模拟搭建两台Nginx服务器. 

    我这里已经事先准备好,不早多详述


    配置反向服务代理器:
    什么是反向服务呢? 首先说下正向服务, 例如爬虫程序, 我们主动出击去获取资源. 而反向服务我们是等待用户来访问. 区别在于主动和被动.
    配置文件Nginx/conf/nginx.conf


    配置Nginx转发条件


    重启Nginx服务器



    为了测试, 我们在两个Tomcat 服务器的index.jsp中分别加了这是来自于哪个ip下的Tomcat. 如下图所示:




    重启好Nginx后, 我们再来访问192.168.200.129 这台机器, 我么可以发现其实访问的是129.168.200.130这台机器.



    负债均衡的配置, 配置转发的权重: (另一台CentOS02 依然按照CentOS01的配置)


    我们在这里配置了两台转发机器: 192.168.200.129和192.168.200.130, 它们的权重分别是2/3 和1/3, 也就是说访问三次192.168.200.129, 有两次是192.168.200.129上的Tomcat来处理, 有一次是192.168.200.130上的Tomcat来处理. 如果我们的Tomcat服务器更多 那么就需要在这里配置更多, 权重根据实际需求来划分.

    同上, 搭建另一台机器192.168.200.130的负载均衡:



    搭建Keepalived:(Keepalived需要依赖openssl)
    这里如果我们的机器192.168.200.129 出现故障了呢? 那么怎么使用192.168.200.130上的Nginx进行转发呢? 怎么设置主机和备机呢? 如果主机死了怎么进行故障移除呢? 如果主机从不可用到可用状态又怎么进行恢复添加呢? 这些功能都是可以通过Keepalived来进行设置的.


    Keepalived原理:

    首先Keepalived可以在主机上产生一个虚拟的ip, 这里叫做vip(v是virtual的意思):192.168.200.150, keepalived会将这个vip绑定到交换机上.
    当用户访问主机:192.168.200.129时, 交换机会通过这个ip和vip的对应找到192.168.200.129上的Nginx进行处理.
    如果当有一天192.168.200.129上的Nginx挂掉的时候, Keepalived会立即在备机上生成一个相同的vip: 192.168.200.150, 当用户继续访问192.168.200.129时, 交换机上已经绑定了vip, 这时发现这个vip是存在于192.168.200.130上面的, 所以直接将请求转发到了备机上. 
    如果主机被修复好能够继续对外提供服务时, 这时keepalived会将主机上继续生成这个vip, 同时回收在备机上生成的vip. 这个是通过心跳检查来判断主机已恢复使用.


    我这里已经提前安装好了oppenssl, 关于具体安装方法大家可以自行百度. 
    检查openssl 是否安装成功: 


    Keepalived的安装命令:


    查看Keepalived的安装目录:


    编辑Keepalived的配置文件:

    首先我们来清空配置文件(清空后会自动再生成一个keepalived.conf, 但是里面的内容为空)
    关于为什么要清空, 因为我们已经配置好了一些相关内容, 直接使用即可.

    这里是来设置虚拟IP和eth1:
    因为我的CentOS是拷贝过来的, 所以这里是eth1, 关于怎么查看, 我们在文章开头有查看本机ip: ifconfig, 那里面有显示我们的网卡就是eth1.




    配置完成之后, 启动keepalived:


    检测Keepalived是否启动成功:

    这里查看 我们的机器多了两个ip, 其实这两个ip都是虚拟ip

    设置备机:|
    这里的权重只要低于主机的100就好.


    启动备机的Keepalived:



    当主机停止服务时, 备机即可接管继续服务:

  • 相关阅读:
    (转)golang获取当前时间、时间戳和时间字符串及它们之间的相互转换
    FFmpeg常用命令
    go cmd nohup 的坑
    Nginx配置详解(转)
    记录一次go性能调试的过程
    github徽标引入
    golang 关于 interface 的学习整理
    <转>Go语言TCP Socket编程
    [转]Go里面的unsafe包详解
    linux extglob模式 和rm反选
  • 原文地址:https://www.cnblogs.com/inkwhite/p/10670467.html
Copyright © 2011-2022 走看看