热门标签 | 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类型集群实现


推荐阅读
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • iOS snow animation
    CTSnowAnimationView.hCTMyCtripCreatedbyalexon1614.Copyright©2016年ctrip.Allrightsreserved.# ... [详细]
  • 如何解决TS1219:实验性装饰器功能可能在未来版本中更改的问题
    本文介绍了两种方法来解决TS1219错误:通过VSCode设置启用实验性装饰器,或在项目根目录下创建配置文件(jsconfig.json或tsconfig.json)。 ... [详细]
  • packagecom.panchan.tsmese.utils;importjava.lang.reflect.ParameterizedType;importjava.lang. ... [详细]
  • 本文介绍了Java编程语言的基础知识,包括其历史背景、主要特性以及如何安装和配置JDK。此外,还详细讲解了如何编写和运行第一个Java程序,并简要介绍了Eclipse集成开发环境的安装和使用。 ... [详细]
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • Bootstrap 缩略图展示示例
    本文将展示如何使用 Bootstrap 实现缩略图效果,并提供详细的代码示例。 ... [详细]
  • MySQL 数据库连接方法
    本文介绍了如何使用 MySQL 命令行工具连接到指定的数据库。 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • 本文介绍了 AngularJS 中的 $compile 服务及其用法,通过示例代码展示了如何使用 $compile 动态编译和链接 HTML 元素。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • ZooKeeper 入门指南
    本文将详细介绍ZooKeeper的工作机制、特点、数据结构以及常见的应用场景,包括统一命名服务、统一配置管理、统一集群管理、服务器动态上下线和软负载均衡。 ... [详细]
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社区 版权所有