一安装LVS准备:

1、准备4台Centos 6.2 x86_64

注:本实验关闭 SELinux和IPtables防火墙。

管理IP地址 角色 备注
192.168.1.101 LVS主调度器(Master Director) 对外提供服务的VIP为192.168.1.180
192.168.1.114 LVS从调度器(Backup Director) 平时可以作为RS(真实服务器使用)
192.168.1.104 RS1(真实服务器)  
192.168.1.103 RS2(真实服务器)  

2、配置好简单的HTTP服务

这里以apache服务为例,通过yum -y install httpd 的方式安装好httpd服务。

分别在192.168.1.103和192.168.1.104上做如下操作:

  1. [root@centos ~]# yum -y install httpd
  2. echo 103 >/var/www/html/index.html #(104上的要把 103字段改成 104)
  3. [root@centos ~]# service httpd start #启动http服务
  4. [root@centos ~]# ps -ef | grep httpd #检查进程如有类似的输出表示启动成功。
  5. root 1535 1 0 23:27 ? 00:00:00 /usr/sbin/httpd
  6. apache 1537 1535 0 23:27 ? 00:00:00 /usr/sbin/httpd
  7. apache 1538 1535 0 23:27 ? 00:00:00 /usr/sbin/httpd
  8. apache 1539 1535 0 23:27 ? 00:00:00 /usr/sbin/httpd
  9. [root@centos ~]# setenforce 0 #关闭SELinux
  10. [root@centos ~]# /etc/rc.d/init.d/iptables stop #关闭防火墙

3、测试http服务配置:

注:用IP地址最后一段数字代表RS自身的内容,容易让大家看到测试的结果,实际业务中,RS的业务内容应该是完全相同的。

4、开始安装LVS

下载相关软件包:

  1. [root@centos1 ~]# mkdir download
  2. [root@centos1 ~]# cd download/
  3. [root@centos1 download]# wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.24.tar.gz

5、安装命令

注:以下安装需要在192.168.1.101和192.168.1.104上面操作:

  1. [root@centos1 download]# uname -r #查看linux内核版本
  2. 2.6.32-220.el6.x86_64
  3. [root@centos1 download]# ln -s /usr/src/kernels/2.6.32-220.el6.x86_64/ /usr/src/linux #不做此步骤,安装会报错
  4. 注:此ln命令的路径要和uname -r输出内核版本一致,如果没有 /usr/src/kernels/2.6.32-220.el6.x86_64/ 需要安装 kernel-devel软件包。
  5. [root@centos1 download]# tar zxvf ipvsadm-1.24.tar.gz
  6. [root@centos1 download]# cd ipvsadm-1.24
  7. [root@centos1 ipvsadm-1.24]# make
  8. [root@centos1 ipvsadm-1.24]# make install
  9. [root@centos1 ipvsadm-1.24]# ipvsadm #执行ipvsadm命令,把LVS添加到linux内核中
  10. IP Virtual Server version 1.2.1 (size=4096)
  11. Prot LocalAddress:Port Scheduler Flags
  12. -> RemoteAddress:Port Forward Weight ActiveConn InActConn
  13. [root@centos1 ipvsadm-1.24]# lsmod | grep ip_vs #查看LVS是否已经添加到linux内核了,如果有如下输出表示已经成功。
  14. ip_vs 108133 0
  15. ipv6 322029 154 ip_vs,ip6t_REJECT,nf_conntrack_ipv6,nf_defrag_ipv6

6配置LVS 服务端

在192.168.1.101和192.168.1.114上分别配置LVS DR模式

1)、配置LVS,建立一个脚本配置LVS

注:192.168.1.101和192.168.1.114上配置都是一样的

[root@centos1 bin]# vim lvs_dr.sh

  1. #!/bin/bash
  2. . /etc/init.d/functions
  3. vim lvs_dr.sh
  4. #!/bin/bash
  5. GW=192.168.1.1
  6. # website director vip.
  7. SNS_VIP=192.168.1.181
  8. SNS_RIP1=192.168.1.103
  9. SNS_RIP2=192.168.1.104
  10. logger $0 called with $1
  11. case "$1" in
  12. start)
  13. # set squid vip
  14. /sbin/ipvsadm --set 30 5 60
  15. /sbin/ifconfig eth0:0 $SNS_VIP broadcast $SNS_VIP netmask 255.255.255.255 up
  16. /sbin/route add -host $SNS_VIP dev eth0:0
  17. /sbin/ipvsadm -A -t $SNS_VIP:80 -s wrr -p 3
  18. /sbin/ipvsadm -a -t $SNS_VIP:80 -r $SNS_RIP1:80 -g -w 1
  19. /sbin/ipvsadm -a -t $SNS_VIP:80 -r $SNS_RIP2:80 -g -w 1
  20. touch /var/lock/subsys/ipvsadm >/dev/null 2>&1
  21. ;;
  22. stop)
  23. /sbin/ipvsadm -C
  24. /sbin/ipvsadm -Z
  25. ifconfig eth0:0 down
  26. ifconfig eth0:1 down
  27. route del $SNS_VIP
  28. route del $SS_VIP
  29. rm -rf /var/lock/subsys/ipvsadm >/dev/null 2>&1
  30. echo "ipvsadm stoped"
  31. ;;
  32. status)
  33. if [ ! -e /var/lock/subsys/ipvsadm ];then
  34. echo "ipvsadm stoped"
  35. exit 1
  36. else
  37. echo "ipvsadm OK"
  38. fi
  39. ;;
  40. *)
  41. echo "Usage: $0 {start|stop|status}"
  42. exit 1
  43. esac
  44. exit 0
  1. [root@centos1 bin]# chmod +x lvs_dr.sh #给SHELL脚本加上执行权限
  2. [root@centos1 bin]# cp lvs_dr.sh /etc/rc.d/init.d/ #方便启动
  3. [root@centos1 bin]# service lvs_dr.sh start #启动lvs服务

用ipvsadm -Ln 命令查看是否有如下输出,如有证明LVS配置成功

  1. [root@centos1 bin]# ipvsadm
  2. IP Virtual Server version 1.2.1 (size=4096)
  3. Prot LocalAddress:Port Scheduler Flags
  4. -> RemoteAddress:Port Forward Weight ActiveConn InActConn
  5. TCP 192.168.1.181:http wrr persistent 3
  6. -> 192.168.1.104:http Route 1 0 0
  7. -> 192.168.1.103:http Route 1 0 0

7、配置LVS RS服务器

[root@centos bin]# vim lvs_dr.sh

  1. #!/bin/bash
  2. . /etc/init.d/functions
  3. SNS_VIP=192.168.1.181
  4. case "$1" in
  5. start)
  6. ifconfig lo:0 $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP
  7. /sbin/route add -host $SNS_VIP dev lo:0
  8. echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
  9. echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
  10. echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
  11. echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
  12. sysctl -p >/dev/null 2>&1
  13. echo "RealServer Start OK"
  14. ;;
  15. stop)
  16. ifconfig lo:0 down
  17. route del $SNS_VIP >/dev/null 2>&1
  18. echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
  19. echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
  20. echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
  21. echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
  22. echo "RealServer Stoped"
  23. ;;
  24. *)
  25. echo "Usage: $0 {start|stop}"
  26. exit 1
  27. esac

[root@centos bin]# cp lvs_dr.sh /etc/rc.d/init.d/  #方便启动

[root@centos bin]# service lvs_dr.sh start  #启动lvs RS服务器

RealServer Start OK

8、验证LVS DR模式是否配置成功

在浏览器中输入 LVS  http://192.168.1.181

然后打开另一个浏览器再次输入 http://192.168.1.181 看看内容是否一样

两个浏览器访问的内容不同,证明LVS DR模式配置成功

到此LVS DR模式已经配置完成,下面配置LVS DR + Keepalived 高可用负载均衡。

http://www.centoscn.com/CentosServer/cluster/2014/0729/3380.html

CentOS下LVS DR模式负载均衡配置详解的更多相关文章

  1. LVS DR模式 负载均衡服务搭建

    LVS 负载均衡 最近在研究服务器负载均衡,阅读了网上的一些资料,发现主要的软件负载均衡方案有nginx(针对HTTP服务的负载均衡),LVS(针对IP层,MAC层的负载均衡).LVS模式工作在网络层 ...

  2. Nginx 负载均衡原理简介与负载均衡配置详解

    Nginx负载均衡原理简介与负载均衡配置详解   by:授客  QQ:1033553122   测试环境 nginx-1.10.0 负载均衡原理 客户端向反向代理发送请求,接着反向代理根据某种负载机制 ...

  3. Nginx + Tomcat 负载均衡配置详解

    Nginx常用操作指南一.Nginx 与 Tomcat 安装.配置及优化1. 检查和安装依赖项 yum -y install gcc pcre pcre-devel zlib zlib-devel o ...

  4. nginx负载均衡配置详解

    已经了解了负载均衡的常用算法:轮询,加权轮询,热备等... 接下来就看看具体怎么配置. upstream配置是写一组被代理的服务器地址,然后配置负载均衡的算法. upstream mysvr{ ser ...

  5. CentOS下Redis 2.2.14安装配置详解(转载)

    一. 下载redis最新版本2.2.14 cd /usr/local/src wget –c http://redis.googlecode.com/files/redis-2.2.14.tar.gz ...

  6. 阿里云、腾讯云、CentOS下的MySQL的安装与配置详解

    一. 安装 查看是否已安装 # 查看MySQL版本 mysql --version # 查看MySQL相关文件 whereis mysql 若已安装,卸载方法如下 # 卸载MySQL yum remo ...

  7. LVS+Keepalived-DR模式负载均衡高可用集群

    LVS+Keepalived DR模式负载均衡+高可用集群架构图 工作原理: Keepalived采用VRRP热备份协议实现Linux服务器的多机热备功能. VRRP,虚拟路由冗余协议,是针对路由器的 ...

  8. 用nginx进行同一个服务器下多域名的负载均衡配置

    用nginx进行同一个服务器下多域名的负载均衡配置 Nginx进行http负载均衡的模块是upstream Upstream可以进行多个配置,这样的话可以灵活的配置站点,但是注意的是upstream后 ...

  9. [转帖]Nginx服务器的六种负载均衡策略详解

    Nginx服务器的六种负载均衡策略详解 咔咔侃技术 2019-09-11 17:40:12 一.关于Nginx的负载均衡 在服务器集群中,Nginx起到一个代理服务器的角色(即反向代理),为了避免单独 ...

随机推荐

  1. Android 插件技术:动态加载dex技术初探

    1.Android动态加载dex技术初探 http://blog.csdn.net/u013478336/article/details/50734108 Android使用Dalvik虚拟机加载可执 ...

  2. 树莓派 离线安装 apt-get offline

    有网络的地方 sudo cp /var/cache/apt/archives/YOUR_PACK_NAME ~/swap/deb/ 没网络的地方 sudo dpkg -i ~/swap/deb/*

  3. Sql Server把本地数据库传到服务器数据库

    上一篇文章我们已经把网站布署到服务器中了,如果是动态网站肯定是有数据库的,接下来通过Sql Server把本地数据库上传到服务器数据库中. 打开Sql Server连接本地数据库,选中要导出的数据库, ...

  4. ESLint - 简介

    ESLint是一个QA工具,用来避免低级错误和统一代码的风格. ESLint被设计为完全可配置的,主要有两种方式来配置ESLint: 在注释中配置:使用JavaScript注释直接把配置嵌入到JS文件 ...

  5. Java:核心概念j积累(一)

    1.      抽象 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节.抽象包括两个方面,一是过 ...

  6. spark性能优化(包括优化原理及基本方法)

    https://www.jianshu.com/p/b8841a8925fb spark性能优化 1.诊断内存的消耗 2. 高性能序列化类库 3. 优化数据结构 4. 对多次使用的rdd进行持久化或者 ...

  7. js控制页面跳转,清缓存,强制刷新页面

    单看标题,必定满脸蒙13. 其实,想表达的仅仅是,在js中通过window.location.href控制页面跳转时,有时会跳转至缓存页面,并没有真正去请求要跳转的地址,导致页面数据未能及时加载刷新. ...

  8. 快速开发框架天梭(Tissot)

    天梭(Tissot)集成SpringBoot+Dubbo等主流互联网技术栈,高度集成.优化方便快速搭建应用.某互金科技公司内部孵化框架,已应用于公司90%业务系统. 框架划分模块有: tissot-c ...

  9. 数组(Arry)几个常用方法的详解

    join() 方法用于把数组中的所有元素放入一个字符串.元素是通过指定的分隔符进行分隔的. arrayObject.join(separator)separator 可选.指定要使用的分隔符.如果省略 ...

  10. Eureka 整理

    服务治理:(该模块也可以使用集群) 该模块主要负责完成微服务架构中的服务治理功能. 1.构建服务注册中心. 每个服务单元需要向注册中心登记自己提供的服务. 2.服务注册与服务发现. 服务之间的调用不再 ...