热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LVS中ipvsadm的使用方法及NAT类型集群实现

LVS中实现负载均衡调度的规则生成工具是ipvsadm,程序包就是ipvsadm。安装:在centos64位上安装ipvsadm:#yuminstallipvsadm–y安装后键入

LVS中实现负载均衡调度的规则生成工具是ipvsadm,程序包就是ipvsadm

安装:

centos64位上安装ipvsadm

#yum install ipvsadm –y

安装后键入#rpm –ql ipvsadm  显示出如下信息

#/etc/rc.d/init.d/ipvsadm  服务脚本

#/etc/sysconfig/ipvsadm-config  保存规则的配置文件

#/sbin/ipvsadm  主程序

#/sbin/ipvsadm-restore  从文件中恢复规则并生效的程序

#/sbin/ipvsadm-save  保存至文件程序的程序

#/usr/share/doc/ipvsadm-1.26

#/usr/share/doc/ipvsadm-1.26/README

#/usr/share/man/man8/ipvsadm-restore.8.gz  restoreman文档

#/usr/share/man/man8/ipvsadm-save.8.gz  saveman文档

#/usr/share/man/man8/ipvsadm.8.gz  主程序man文档

使用方法:

管理集群服务:创建、修改、删除

管理集群服务:

创建或修改:

ipvsadm -A|E -t|u|f service-address [-sscheduler]

-A: 添加

-E:修改

-t: 承载的应用层协议为基于TCP协议提供服务的协议;其service-address的格式为“VIP:PORT”,如“172.16.50.2:80”;

-u: 承载的应用层协议为基于UDP协议提供服务的协议;其service-address的格式为“VIP:PORT”,如“172.16.50.3:53”;

-f:承载的应用层协议为基于TCPUDP协议提供服务的协议,但此类报文会经由iptables/netfilter打标记,即为防火墙标记;其service-address的格式为(一个数字即可)“FWM”,例如“10”;例如:可以将TCP80端口标记上10UDP443端口标记上10从而将两个集群服务做成一个集群服务。

-s scheduler: 指明调度方法;默认为wlc

举例:

技术分享

删除:

ipvsadm -D -t|u|f service-address

举例:

技术分享

管理集群服务上的RS

添加或修改:

ipvsadm -a|e -t|u|f service-address -rserver-address [-g|i|m] [-w weight]

-r server-address: 指明RSserver-address格式一般为“IP[:PORT]”;注意,只支持端口映射的lvs类型中才应该显式定义此处端口;例如:-r 172.16.50.1

[-g|i|m]: 指明lvs类型,默认为dr类型

-g: gateway, 意为dr类型;

-i: ipip, 意为tun类型;

-m: masquerade, 意为nat类型;

[-w weight]:当前RS的权重;注意:仅对于支持加权调度的scheduler,权重才有意义;

举例:

技术分享

删除:

ipvsadm -d -t|u|f service-address -rserver-address

举例:

技术分享

清空所有集群服务的定义:

ipvsadm –C

举例:

技术分享

保存及恢复集群服务及RS的定义:

ipvsadm -S > /etc/sysconfig/ipvsadm或者ipvsadm-save> /etc/sysconfig/ipvsadm或者service ipvsadm save

举例:

技术分享

ipvsadm -R 或者ipvsadm-restore或者service ipvsadm restart

举例:

技术分享

查看规则:

ipvsadm -L|l [options]

-c: 列出当前所有connection

-n, --numeric: 数字格式显示IP及端口;

举例:

技术分享

--stats: 列出统计数据

举例:

技术分享

--rate: 列出速率

举例:

技术分享

--exact: 精确值;(据我看好像和没加这个参数显示的是一样的)

举例:

技术分享

清空计数器:

ipvsadm -Z [-t|u|f service-address]

举例:(真的会清哦)

技术分享

搭建NAT类型的web服务集群

如:要实现ipvs_nat类型的搭建,首先准备三个linux虚拟机,centos64位(简称:V1)用作directorcentos64位(2)(简称:V2)、centos64位(3)(简称:V3)作为real server构建一个web服务集群。

由于具体实现调度功能的是ipvs,而ipvs工作在netfilterinput链上,则ipvsiptables两者共同工作会产生冲突,所以,在集群存在的情况下,iptables一般应该关闭。

清除iptables规则并查看

技术分享

V1

一个网卡以桥接方式(vmnet0)与物理机连接

技术分享

再添加一块网卡(vmnet2)以普通模式与V2V3连接

技术分享

V2V3上修改网卡为wmnet2

技术分享

V1中的vmnet2网卡eth1配置成192.168.50.1

技术分享


同样方法,将V2vmnet2类型网络的eth0修改为192.168.50.2V3vmnet2类型网络的eth0修改为192.168.50.3

设置网关为192.168.50.1并查看

技术分享

分别用V2V3测试与V1外网地址的连通性

技术分享

注:若想永久有效可以在V2V3/etc/sysconfig/network-scripts/ifcfg-eth0添加

IPADDR=192.168.50.2

NETMASK-255.255.255.0

GATEWAY=192.168.50.1

BOOTPROTO=”none”

V1中测试与V2V3的连通性

ping -c 1 192.168.50.2

ping -c 1 192.168.50.3

技术分享

保证在V2V3上安装好了httpd,并在V2V3上编辑网页

vim /var/www/html/index.html

技术分享

技术分享

技术分享



然后启动http服务

service httpd start

然后在V1上测试下是否可以访问V2V3的网页

curl http://192.168.50.2

curl http://192.168.50.3

技术分享

见到上述页面,即可以在V1主机上配置ipvs规则了

技术分享

打开V1中的路由转发功能

vim /etc/sysctl.conf

net.ipv4.ip_forward = 0改成1

技术分享

sysctl的配置立即生效

sysctl –p

技术分享

在主机浏览器中输入172.16.50.1,重复刷新看是否轮询即可。

这样基于rr规则的lvs负载均衡集群就搭建完成喽!

也可以更换规则类型实现基于其他规则的负载均衡。

妈蛋~写这么多累死了!


LVS中ipvsadm的使用方法及NAT类型集群实现


推荐阅读
  • rbac 4表 常规设计
    rbac4表常规设计设计模型:1、管理员表(users)Schema::create('users',function(Blueprint$table){$tabl ... [详细]
  • kepserver中文手册,kepserver使用教程,kepserver设置
    下面介绍一下KepServer模拟器的使用,以下示例使用服务器随附的Simulator驱动程序来演示创建、配置和运行项目的过程。Simulator驱动程序是基于内存的驱动程序,能为 ... [详细]
  • packagetest;importjava.io.FileInputStream;importjava.io.FileOutputStream;importjava.io.IOE ... [详细]
  • 安全3AAuthentication:认证Authorzation:授权Accouting|Audition:审计用户管理用户:UID:0,不一定是root,root的uid非0时 ... [详细]
  • 抓取百万知乎用户设计之实体设计
    一.实体的关系实体是根据返回的Json数据来设计的教育经历方面用户可以有很多教育经理,USER和education是一对多的关系,一个education对应一个education一 ... [详细]
  • iOS之富文本
    之前做项目时遇到一个问题:使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结 ... [详细]
  • Xib九宫格应用管理使用xib封装一个自定义view的步骤1新建一个继承UIView的自定义view,假设类名叫做(AppView)2新建一个AppView.xib文件来描述 ... [详细]
  • 【自制小工具】代码生成器
    【自制小工具】代码生成器陆陆续续接触过好几款代码生成工具,发现确实好用,但都会有那么点不完善的地方,所以索性就自己做一个吧。界面非常简单,反正是自己用的,简单点用起来也方便上图:左 ... [详细]
  • 作业迁移
    背景:数据库服务器更换,1、数据库迁移(BACKUPRESTORE);2、数据库登录名用户迁移(注意孤立用户);3、作业迁移数据库迁移,备份数据库、拷贝备份文件到新服务器,还原数据 ... [详细]
  • Linux     系统安装
    Linux系统安装linux系统安装准备工作电脑、u盘、光盘、网络、硬盘主要使用光盘、网络虚拟化软件vmwarevi ... [详细]
  • 定义:定义两个数论函数\(f\)、\(g\)的Dirichlet卷积为:\[\left(f*g\right)\left(n\right)\sum_{d|n}f\left(d\rig ... [详细]
  • 读书这件事
    没事晒下自己的借书清单。60多本了,不知道自己一本子能读多少本?可惜的就是没写读书笔记,都是一些泛读。图书馆要 ... [详细]
  • phpstorm使用和配置技巧
    1.使用phpstorm的过程中,有时光标不小心变成了方块状,怎么修复回来呢?见下图,去掉“Useblockcare ... [详细]
  • vector:在vc6中,如果要镶嵌使用vector,如vector,后面的两个应该用,空格隔开,否则被编译器认为是移位符string::npos的值为 ... [详细]
  • Spark 贝叶斯分类算法
    一、贝叶斯定理数学基础我们都知道条件概率的数学公式形式为即B发生的条件下A发生的概率等于A和B同时发生的概率除以B发生的概率。根据此公式变换,得到贝叶斯公式:即贝叶斯定律是关于随机 ... [详细]
author-avatar
winnie198808616
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有