集群-ipvsadm和NAT实验(3)

纠正:报文进入内核空间后,当到达input链时发现是一个集群服务时,则直接发送到postrouting链,不经过forward链。

调度算法:

1、静态方法:

rr:轮询,即依照次序从所有RS中进行挑选

wrr:加权轮询,按照权重在RS中进行轮询

sh:source hashing,源地址哈希,即对来自相同客户端的请求发送至同一RS,这样会破坏负载均衡效果。可以基于cookie实现session绑定。

dh:destination hash,目标地址哈希,将同样的请求发给同一个RS。可以提高缓存命中率。

2、动态方法:

lc:最少连接。(活动连接数*256+非活动连接数),谁的最小就是谁。

wlc:加权最少连接。(活动连接数*256+非活动连接数)/weight,谁的最小就是谁。

sed:最少期望延迟。不再考虑非活动连接。(活动连接数+1)*256/weight,谁的最小就是谁。

nq:最少队列调度,改进的sed算法,也不考虑非活动连接数。无需队列。如果有台realserver的连接数=0就直接分配过去,不需要在进行sed运算。

lblc:基于本地的最少连接。和dh一样,考虑cache的连接数。可能破坏缓存命中率。

lblcr:基于本地的带复制功能的最少连接。如果一台服务器的访问过高,可以将缓存复制给其他服务器前面的缓存服务器,然后由其他服务器提供服务。缓存服务器之间会部分复制缓存。

生产环境中比较理想的是wlc,因为非活动连接可能是无法忽略的。

安装ipvsadm及命令详解:

yum直接安装ipvsadm即可。

grep -i 'vs' /boot/config-2.6.32-504.el6.x86_64   #即可查看ipvsadm的相关算法等信息

主要功能:

1、管理集群服务:
    添加:ipvsadm -A|E -t|u|f service-address [-s scheduler] [-p [timeout]] [-M netmask]
        -t|u|:tcp|udp
            service-address:ip:port
        -f:防火墙标记
            service-address:mark number
        默认使用wlc算法
    修改:同上
    删除:ipvsadm -D -t|u|f service-address
2、管理集群中RS:
    添加:ipvsadm -a|e -t|u|f service-address -r server-address [-g|i|m] [-w weight] [-x upper] [-y lower]
        service-address:先定义的集群服务
        -r server-address:RS地址,在NAT模型中可以使用ip:port来做端口映射
        [-g|i|m]:g,DR模型;i,TUN模型;m,地址伪装NAT模型,默认为DR模型
        -w weight:权重,若集群不指定权重,则此处无意义 
    修改:同上
    删除:ipvsadm -d -t|u|f service-address -r server-address
3、查看
    -L|l:查看
        -n:数字格式显示ip和端口
        --stats:显示统计信息
        --rate:显示速率
        --timeout:显示tcp,tcpfin,udp超时
        --daemon:显示多播等信息
        --sort:排序
        -c:显示连接状态
-Z:清空计数器
-C:清空所有集群服务
保存规则:
    -S > 文件(使用输出重定向)
    或者service ipvsadm save,自动保存至/etc/sysconfig/ipvsadm中
导入规则:
    -R < 文件(使用输入重定向)

实验:

前提:

1、时间得同步。尤其是以后的高可用模型对时间同步要求很严格。

2、改主机名

3、directory(调度器)的两块网卡之间得打开转发功能

blob.png

IP规划如上图

开启网卡转发功能:

blob.png

Directory网络配置(eth0设置为桥接,eth1设置为仅主机模式):

blob.png

RS网络设置

RS1:(网卡设置为仅主机模式)

blob.png

RS2:(网卡设置为仅主机模式)

blob.png

添加集群服务并查看 

blob.png

blob.png

在RS中添加默认网页:

echo “RS1” > /var/www/html/index.html
echo “RS2” > /var/www/html/index.html

再RS中启动httpd服务:service httpd start

查看一下index.html文件:

blob.png(此处未改主机名)

blob.png(此处未改主机名)

在网页中输入192.168.0.20并刷新

blob.png

blob.png

保存规则并查看:

blob.png

blob.png

清空规则并查看:

blob.png

此时已无规则。

导入规则并查看:

blob.png

DR模型:

blob.png

Director配置:(配置DIP,VIP,添加路由)

blob.png

blob.png

RS1配置:

blob.png

(此处未改主机名)

[root@RS1 ~]# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore 
[root@RS1 ~]# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore 
[root@RS1 ~]# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce 
[root@RS1 ~]# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

配置vip:

[root@RS1 ~]# ifconfig lo:0 192.168.0.21 broadcast 192.168.0.21 netmask 255.255.255.255 up

添加路由:

[root@RS1 ~]# route add -host 192.168.0.21 dev lo:0

RS2配置:

blob.png

(此处未改主机名)

[root@RS2 ~]# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore 
[root@RS2 ~]# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore 
[root@RS2 ~]# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce 
[root@RS2 ~]# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

配置VIP:

[root@RS2 ~]# ifconfig lo:0 192.168.0.21 broadcast 192.168.0.21 netmask 255.255.255.255 up

配置路由:

[root@RS2 ~]# route add -host 192.168.0.21 dev lo:0

Director添加集群服务并查看

blob.png

浏览器查看:

blob.pngblob.png

原创文章,作者:黑白子,如若转载,请注明出处:http://www.178linux.com/9488

(0)
黑白子黑白子
上一篇 2015-12-15
下一篇 2015-12-15

相关推荐

  • Linux编译安装

    Linux编译安装    Linux上真正可以执行的文件是二进制文件,这些可以执行的二进制文件是哪儿来的呢?首先,必须要写程序的源代码,然后,由编译程序将程序的源代码 编译成二进制形式。源代码是由程序员编写的,使用特定的程序语言,如C,C++,Java,Python。但是机器看不懂这些语言,所以要使用编译程序将这些语言编写的源代码编译成机…

    Linux干货 2016-08-24
  • Nginx+resin调优文档[原创]

    为什么不选择Apache/mod+resin?       前面一直使用该模式,mod_caucho暴露源码的bug一直未得到彻底的解决。因此切换到Nginx+resin平台。硬件上要求除了内存一定要足够大(建议>4G),无其它要求(当然也不能太破,呵呵)。操作系统强烈要求安装64位,32位操…

    Linux干货 2015-03-27
  • Bonding多块网卡绑定同一IP地址

    Bonding多块网卡绑定同一IP地址 就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。 一共有七种模式这里提供三种常用的:   一、Mode 0 (balance-rr)  轮转( Round-robin…

    Linux干货 2016-09-07
  • Linux文件管理和Bash特性

    一、Linux基本文件管理命令 主要介绍cp、mv、rm命令的基本用法以及使用示例 cp命令 cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录 cp (选项) (参数) 常用选项: -a:此参数的效果和同时指定”-dpR”参数相同,用于实现归档; -d:复制符号链接文件本身,而非其指向的源文件; -f:强行复制文件或目录,不论目标文件或目录是…

    Linux干货 2017-07-09
  • bash的重定向

    一、简介         bash的数据流重定向(redirect)是将程序的执结果重新定向到另一文件或者设备。或者把一文件重定向给一程序作为数据来源。默认情况下,命令的执行结果显示在屏幕上。文件系统中,分为:标准输入,标准输出,错误输出。 二、用法   &n…

    Linux干货 2015-08-11
  • M20 – 1- 第二周博客(2):Linux的文件系统与结构

    Linux系统对于一个初学者来说,其实并不那么容易.所以了解其系统的结构,及其表示的含义是非常重要的.否则安装好系统后,都无从下手.也不知道怎么办。下面介绍一下Linux 的目录结构.及每个目录表示的含义.方便初学者学习和使用Linux系统。 从上图可以看出Linux的目录结构属于树状型的,是否已经对Linux的结构有个大概的认识了呢,接下来讲的是这些目录中…

    Linux干货 2016-08-02

评论列表(1条)

  • stanley
    stanley 2015-12-15 22:46

    哈,很不错,不过最核心的 arp_announce 原理呢?