LVS - FULLNAT内核编译方法 Fullnat其实也就是nat类似原理,只是需要在调度器DR上进行进行源目地址转发,首先介绍一下,CIP:客户端请求ip,DIP:调度器端的ip,RIP:提供服务的真实主机的ip,由于DIP和RIP之间可以经过路由转换,所以后端提供服务的real-server可以进行无限扩展,再通过调度器对后端服务的调用,可以完美解决负载均衡,但是存在单点故障,因此还需要结合类似:heartbeat,keepalived,pacemaker,以及红帽rhcs套件来解决单点故障。这样系统就非常健壮了,言归正传,当客户端请求报文到达源目IP分别为CIP和VIP。达到调度器DR后,经过ipvs通过算法调度后台的真机real-server,但是由于DIP和RIP并不在同一个网段,所以IPVS会将请求的报文源目IP分别改为DIP和RIP,RS收到报文后,就会将相应报文发给DR,DR通过内部追踪nat表后,在将响应的报文源目IP分别改为VIP和CIP,于是响应的报文就发给了客户端client,这种对源目IP均做修改的LVS类型就称为FULNAT模式。
首先下载阿里的修改过后的内核: 准备材料:asciidoc-8.4.5-4.1.el6.noarch.rpm kernel-2.6.32-220.23.1.el6.src.rpm newt-devel-0.52.11-3.el6.x86_64.rpm slang-devel-2.2.1-1.el6.x86_64.rpm Lvs-fullnat-synproxy.tar.gz #yum provides */rngd #查找rgnd这个命令的安装包 #yum install -y rng-tools-2-13.el6_2.x86_64 安装查找的rgn命令的 #rngd -r /dev/urandom :加快对内核的安装 进行磁盘拉伸 +20G #pvcreate /dev/vdb #vgextend VolGroup /dev/vdb #lvextend -L +27G /dev/VolGroup/lv_root #resize2fs /dev/VolGroup/lv_root ##进行正式修改内核; # rpm -ivh kernel-2.6.32-220.23.1.el6.src.rpm #安装内核安装包 #yum install -y rpm-build #安装rpm-build工具 #cd /RPM/rpmbuild/SPECS/ #rpmbuild -bp kerbel.spec #rpmbuild编译kernel.spec文件 #然后解决各种依赖性,注意倒数第二个改为perl-ExtUtils-Embed # #yum install -y asciidoc-8.4.5-4.1.el6.noarch.rpm newt-devel-0.52.11-3.el6.x86_64.rpm slang-devel-2.2.1-1.el6.x86_64.rpm #解决各种依赖性 # rpmbuild -bp kernel.spec #在另外一个客户端登陆执行:#rngd -r /dev/urandom 速度会马上安装好。 #进入kernel-2.6.32.-220.23.1.el6目录里; #lftp 获得 Lvs-fullnat-synproxy.tar.gz文件 :解压该文件,获得内核的补丁 #tar zxf Lvs-fullnat-synproxy.tar.gz #cd lvs-fullnat-synproxy #cp lvs-2.6.32--220.23.1.el6.patch ../linux-2.6.32-220.23.1.el6.x86_64/ #yum install -y patch #cd ../linux-2.6.32-220.23.1.el6.x86_64/ #patch -p1 < lvs-2.6.32--220.23.1.el6.patch #打补丁打入到内核 #vim .config CONFIG_IP_VS_TAB_BITS=22 修改为22位 #vim Makefile :添加延伸延伸版本号 EXTRAVERTION = -220.23.1.el6 #make -j2 :编译内核, #make modules_install :安装模块 #make install :安装内核 #vim /etc/grub.conf :修改启动项。 10行 default=0 ##使之重起更换内核。使用刚才修改过后的内核。 如果需要获取客户端的ip时,则也需要更改real-server的内核,对real-server的内核进行打toa补丁,动态加载toa模块,从而使得realserver可以获得客户端的ip地址 -i :TUN模式 -b :FULLNAT模式 -m :NAT模式 -g :DR模式 VS上安装ipvsadm工具,使其支持fullnat 也就是-b模式。 #安装ipvsadm工具,使得它支持fullnat模式, #cd rpmbuild/BUILD/kernel-2.6.32-220.23.1.el6/lvs-fullnat-synproxy/ #cp lvs-tools.tar.gz ~ #tar zxf lvs-tools.tar.gz #keepalived的编译。 #cd keepalived/ #yum install -y openssl-devel #yum install -y popt-devel :解决安装ipvsadm的依赖性问题。 #./configure --with-kernel-dir="/lib/modules/`uname -r`/build" #make ---> make install Ipvsadm编译 #cd ipvsadm/ #make --> #make install #ipvsadm --help :查看是否有fullnat模式支持。如果有支持fullnat模式的,这说明从新安装的ipvsadm可用。 注意:必须要先编译安装keepalived过后,才能安装ipvsadm命令。
|