NetScaler Active-Active模式

NetScaler Active-Active模式

(此文档基于版本:NS9.3: Build 55.6 nc)

By ShingTan

Active-Active部署,除了减少downtime,最重要的是可以使所有NetScaler都发挥最大作用。在Active-Active部署模式中,所有的NetScaler设备上配置有相同的VIP与不同的权重值,因此一个特定的VIP在某一时刻只能有效活跃在一台设备上。

(注意:Active-Active这个特性只在NetScaler nCore版本中支持。)

这个有效的活跃VIP叫做master VIP,而相应的在其它NetScaler设备上的VIP叫做backup VIP。如果master VIP失效,拥有最高权重的backup VIP将接管并成为master VIP。所有在Active-Active部署模式中的NetScaler设备使用虚拟路由冗余协议(VRRP)定期广播它们的VIP与相应的权重值。

NetScaler设备在Active-Active模式下是可以独立配置的,因此没有NetScaler是空闲的。在这个模式下,不同的VIP集分别活跃在一台NetScaler上。例如,下图中,VIP1、VIP2、VIP3和VIP4都配置在设备NS1、NS2和NS3上。基于它们的权重,VIP1和VIP2活跃在NS1上,VIP3活跃在NS2上,而VIP4活跃在NS3上。如果,NS1失效,VIP1在NS3而VIP2在NS2上变为活跃的。

Active-Active拓扑图

上图中的NetScaler设备处理流量的过程如下:

  1. Client C1发送一个请求到VIP1。请求到达R1。
  2. R1没有关于VIP1的ARP条目,因此它针对VIP1广播一个ARP解析请求。
  3. VIP1在NS1上是活跃的,因此NS1回应有关VIP1的ARP解析请求,以VMAC1作为源MAC地址,VIP1作为源IP地址。
  4. SW1从ARP的响应包里学习到与VIP1相连的端口,并更新它的bridge table。
  5. R1更新有关VMAC1与VIP1的ARP条目。
  6. R1转发数据包到NS1上的VIP1。
  7. NS1上的负载均衡算法选择了S2,NS1使用它的SNIP或MIP与S2建立连接。
  8. S2响应NetScaler的SNIP或者MIP。
  9. NS1发送S2的响应到client。在这个响应包里,NS1插入VMAC地址作为源MAC地址,VIP1作为源IP地址。
  10. 若NS1失效,NetScaler设备使用VRRP协议选择具有最高权重值的VIP1。在这种情况下,VIP1在NS3上被激活,而以下2步将更新active-active配置。
  11. NS3广播VIP1的GARP信息。在这个信息里,VMAC1作为源MAC地址而VIP1作为源IP地址。
  12. SW1从GARP广播里学到VMAC1的新连接端口,更新它的bridge table,并发送后续的client请求到NS3上的VIP1。R1更新它的ARP表。

VIP的权重可以被health tracking修改。如果你启用health tracking,你必须确保preemption也被启用,因此,如果一个VIP的权重值较低,将被另一个VIP抢占成功。

在某些情况下,流量可能到达backup VIP。为了避免丢弃这类流量,在你创建一个active-active结构时可在每节点上启用sharing。或者你可以在全局中启用send to master选项。在一个节点中,如果sharing被启用,它将优先于send to master。

Health Tracking

基础权重值BP(范围1~255)通常决定了哪个VIP是master VIP,有效权重值EP也可以影响这个决策。

例如,如果在NS1上的一个VIP拥有一个101的权重值,而在NS2上相同的VIP拥有一个99的权重值,在NS1上的VIP是活跃的。然而,如果在NS1上有2个VS使用这个VIP,而它们中某一个VS变为DOWN,health tracking将减小NS1上VIP的EP。然后,VRRP将选择NS2上的VIP为有效VIP。

以下是health tracking修改EP的选项:

l  NONE. No tracking. EP = BP

l  ALL. If all virtual servers are UP, then EP = BP. Otherwise, EP = 0.

l  ONE. If at least one virtual server is UP, then EP = BP. Otherwise, EP = 0.

l  PROGRESSIVE. If ALL virtual servers are UP, then EP = BP. If ALL virtual servers are DOWN then EP = 0. Otherwise EP = BP (1 - K/N), where N is the total number of virtual servers associated with the VIP and K is the number of virtual servers that are down.

注意:如果你指定了除NONE以外的值,preemption一定要启用,由此,在master VIP降级期间,具有最高权重值的backup VIP才能抢占为活跃的。

Preemption

抢占模式默认是启用的,而通常情况下也应该启用。当然,在某些情况下,你也可能想disable它。Preemption是每VIP每节点设置的。

Preemption可能在以下情况下发生:

l  An active VIP goes down and a VIP with a lower priority takes its place. If the VIP with the higher priority comes back online, it preempts the currently active VIP.

l  Health tracking causes the priority of a backup VIP to become higher than that of the active VIP. The backup VIP then preempts the active VIP.

Sharing

如果流量到达backup VIP,流量将被丢弃,除非sharing选项在backup VIP上被启用。这个动作是每VIP每节点配置的,缺省是disabled。

在Active-Active拓扑图中,VIP1在NS1上活跃,VIP1在NS2和NS3上是backup的。在某些特定情况下,流量可能到达NS2的VIP1。如果在NS2上启用sharing,流量将被处理而不是被丢弃。

Configuring Active-Active Mode

部署active-active模式,在每台NetScaler设备上,你必须添加一个VMAC并且绑定VMAC到某个VIP。每台设备上给定的VIP都有相同的VMAC。例如,如果在设备上创建一个VIP 192.168.0.79,则一个virtual router ID也必须在每台NetScaler上创建并绑定到VIP 192.168.0.79上。当你把VMAC绑定到VIP,NetScaler将发送VRRP广播到每个绑定VIP的VLAN。VMAC可以被一台NetScaler上的不同VIP共享。

现在我们简单的搭建一个测试环境,参考下图:

添加VMAC

在active-active结构中添加VMAC,先要创建一个virtual router ID。再绑定VMAC到VIP,你需要把VMAC的vrID与VIP关联。

NS命令行下添加VMAC

在NetScaler命令行模式下,输入:

add vrID <value> -priority <value> -preemption (ENABLED|DISABLED) -sharing (ENABLED |DISABLED) -tracking (NONE|ONE|ALL|PROGRESSIVE)

例如:

add vrID 71 -priority 73 -sharing ENABLED -tracking ONE

注:命令行下,preemption缺省是启用的,但GUI界面缺省是未选中。

VMAC参数

vrID

The VRID that identifies the VMAC. Possible values: 1 - 255.

priority

The base priority of the VMAC. Range: 1 - 255. Default: 255.

tracking

The health tracking options for this VMAC. Possible values: NONE, ONE, ALL, PROGRESSIVE Default: NONE.

preemption

Make a backup VIP the master if its priority becomes higher than that of a master VIP that is bound to this VMAC. Possible values: ENABLED, DISABLED. Default: ENABLED.

sharing

Enable or disable sharing for this VMAC. Default: Disabled.

GUI下添加VMAC

在NS1上添加VMAC,

在NS2上添加VMAC,

NS命令行下绑定VMAC

在NS命令行下,输入:

set ns ip VIP <address> -vrid <value>

例如:

set ns ip 192.168.0.79 -vrid 71

GUI下绑定VMACVIP

在NS1上把vrID 71绑定到VIP 192.168.0.79,

在NS2上同样的把vrID 71绑定到VIP 192.168.0.79,

在关联vrID与VIP后,重新回到VMAC配置界面,我们可以看到:

在NS1上,

vrID 71为master,vrID 73为backup,与拓扑相符。

在NS2上,

vrID 71为backup,vrID 73为master,与拓扑相符。

配置Send to Master

通常,目的IP为VIP的流量到达有效VIP所在的NetScaler设备,因为VIP回应ARP解析请求,同时该设备的VMAC返回到上行的路由器。但是在某些情况下,如在上行路由器上配置了针对VIP子网的静态路由,而某个拓扑结构阻断了这个路由,流量可能会到达backup VIP所在的NetScaler设备。如果你想这台backup VIP设备转发数据包到master VIP设备,你需要启用send to master选项。这是单节点配置,缺省是disabled。

例如,在下图中,VIP1在NS1、NS2和NS3都有配置,在NS1上是活跃的。在某些情况下,VIP1的流量(NS1上有效)可能到达NS3上的VIP1。当NS3上的send to master选项被启用,NS3使用到NS1的路由条目通过NS2转发流量到NS1上(此为原文翻译,为何是通过NS2转发流量,而不是通过下行交换网络转发流量?)。

Active-Active模式下启用send to master

NS命令行下启用send to master

在NS命令行下,输入:

set vrIDParam -sendToMaster (ENABLED|DISABLED)

例如:

set vrIDParam -sendToMaster ENABLED

send to master参数

sendToMaster

Forward the packet to the master node if the VIP bound to the VMAC is in backup state and sharing is disabled.

Possible values: ENABLED, DISABLED. Default: DISABLED.

GUI下启用send to master

NetScaler Active-Active模式的更多相关文章

  1. 敏捷软件开发(3)---COMMAND 模式 & Active Object 模式

    COMMAND 模式 command模式非常简单,简单到你无法想象的地方. public interface Command { void execute(); } 这就是一个command模式的样子 ...

  2. Android开源库--ActiveAndroid(active record模式的ORM数据库框架)

    Github地址:https://github.com/pardom/ActiveAndroid 前言 我一般在Android开发中,几乎用不到SQLlite,因为一些小数据就直接使用Preferen ...

  3. Java多线程编程模式实战指南:Active Object模式(下)

    Active Object模式的评价与实现考量 Active Object模式通过将方法的调用与执行分离,实现了异步编程.有利于提高并发性,从而提高系统的吞吐率. Active Object模式还有个 ...

  4. Java多线程编程模式实战指南:Active Object模式(上)

    Active Object模式简介 Active Object模式是一种异步编程模式.它通过对方法的调用与方法的执行进行解耦来提高并发性.若以任务的概念来说,Active Object模式的核心则是它 ...

  5. java Active Object模式(下)

    Active Object模式的评价与实现考量 Active Object模式通过将方法的调用与执行分离,实现了异步编程.有利于提高并发性,从而提高系统的吞吐率. Active Object模式还有个 ...

  6. java Active Object模式(上)

    Active Object模式简介 Active Object模式是一种异步编程模式.它通过对方法的调用与方法的执行进行解耦来提高并发性.若以任务的概念来说,Active Object模式的核心则是它 ...

  7. Java多线程编程模式实战指南一:Active Object模式(下)

    Active Object模式的评价与实现考量 Active Object模式通过将方法的调用与执行分离,实现了异步编程.有利于提高并发性,从而提高系统的吞吐率. Active Object模式还有个 ...

  8. Java多线程编程模式实战指南一:Active Object模式(上)

    Active Object模式简介 Active Object模式是一种异步编程模式.它通过对方法的调用与方法的执行进行解耦来提高并发性.若以任务的概念来说,Active Object模式的核心则是它 ...

  9. Java多线程编程模式实战指南(一):Active Object模式--转载

    本文由黄文海首次发布在infoq中文站上:http://www.infoq.com/cn/articles/Java-multithreaded-programming-mode-active-obj ...

  10. Zabbix Agent active主动模式监控

    zabbix_server端当主机数量过多的时候,由Server端去收集数据,Zabbix会出现严重的性能问题,主要表现如下: 1.当被监控端到达一个量级的时候,Web操作很卡,容易出现502 2.图 ...

随机推荐

  1. CentOS 7 下 jdk8 安装教程

    方法一: 一.下载   官网下载地址   下载需要确认当前系统是32位还是64位,可通过命令查询:   sudo uname --m   根据查询结果下载对应的jdk版本(如):   i686 //表 ...

  2. 实际案例告诉你为什么Oracle不建议使用varchar2来存时间数据

    问题现象2015年9月客户系统中一条高逻辑读的SQL语句,在业务高峰期执行频率较高,导致系统逻辑读居高不下,同时带高了系统CPU,SQL语句主体部分如下 SELECT /* ^^*/ COUNT(DI ...

  3. vue项目不能同时被localhost和ip地址同时访问的方法

    方法1.将index.js中的host的值改为‘0.0.0.0’ 方法2.修改package.json中script下dev的值,在后面加入--host 0.0.0.0 也可以解决

  4. Webpack4 学习笔记五 图片解析、输出的文件划分目录

    前言 此内容是个人学习笔记,以便日后翻阅.非教程,如有错误还请指出 webpack打包图片和划分文件路径 使用图片的方式 通过 new Image() 在 css中设置 background-imag ...

  5. 私有maven库发布及使用流程

    ## 私有maven库发布流程 ### 环境配置 - idea环境下,如果使用内置maven,需要手动生成settings.xml,并关联. - 操作如下 - 生成settings.xml 右键pom ...

  6. Q&A - 如何获取ip地址所在地

    获取其IP地址后,传入以下URL,并请求该URL,该请求会响应一个JSON格式的数据包,该IP地址的所在地均在这个数据包内   http://int.dpool.sina.com.cn/iplooku ...

  7. struts2之标签库

    使用Struts2标签的准备工作: 导入Struts2标签库,该标签定义文件位于 struts2-core-2.3.16.3.jar 的 METE-INF下的struts-tag.tld文件. < ...

  8. 汇编:实现C语言的 ||与&&运算

    ;C程序转汇编(或运算链接) DATAS SEGMENT a Dw b dw cc dw d dw m dw n dw string db dup(?) DATAS ends CODES SEGMEN ...

  9. http协议组成(请求状态码)

    http请求由:请求行:消息报头:请求正文组成 //请求行 Request URL: http://172.32.4.33:8080/operation/v2/autoServer/queryAuto ...

  10. Java基础——对象和类

    将包含main方法的类称为主类. 变量的作用域是指变量可以在程序中引用的范围. 实例变量和静态变量的作用域是整个类,无论变量是在哪里声明的. 局部变量的声明和使用都在一个方法的内部. 一个类的实例变量 ...