[From OpenBSD Man Page]CARP

简介:

NAME

carp – Common Address Redundancy Protocol

SYNOPSIS

pseudo-device carp

DESCRIPTION

The carp interface is a pseudo-device which implements and controls the

CARP protocol.  carp allows multiple hosts on the same local network to

share a set of IP addresses.  Its primary purpose is to ensure that these

addresses are always available, but in some configurations carp can also

provide load balancing functionality.

A carp interface can be created at runtime using the ifconfig carpN

create command or by setting up a hostname.if(5) configuration file for

netstart(8).

To use carp, the administrator needs to configure at minimum a common

virtual host ID (VHID) and virtual host IP address on each machine which

is to take part in the virtual group.  Additional parameters can also be

set on a per-interface basis: advbase and advskew, which are used to con-

trol how frequently the host sends advertisements when it is the master

for a virtual host, and pass which is used to authenticate carp adver-

tisements.  Finally carpdev is used to specify which interface the carp

device attaches to.  If unspecified, the kernel attempts to set it by

looking for another interface with the same subnet.  These configurations

can be done using ifconfig(8), or through the SIOCSVH ioctl.

carp can also be used in conjunction with ifstated(8) to respond to

changes in CARP state; however, for most uses this will not be necessary.

See the manual page for ifstated(8) for more information.

Additionally, there are a number of global parameters which can be set

using sysctl(8):

net.inet.carp.allow         Accept incoming carp packets.  Enabled by de-

fault.

net.inet.carp.preempt       Allow virtual hosts to preempt each other.

It is also used to failover carp interfaces

as a group.  When the option is enabled and

one of the carp enabled physical interfaces

goes down, advskew is changed to 240 on all

carp interfaces.  See also the first example.

Disabled by default.

net.inet.carp.log           Make carp log state changes, bad packets, and

other errors.  May be a value between 0 and 7

corresponding with syslog(3) priorities.  The

default value is 2, which limits logging to

changes in CARP state.

LOAD BALANCING

carp provides two mechanisms to load balance incoming traffic over a

group of carp hosts: ARP balancing and IP balancing.

Which one to use mainly depends on the network environment carp is being

used in.  ARP balancing has limited abilities for load balancing the in-

coming connections between hosts in an Ethernet network.  It only works

for clients in the local network, because ARP balancing spreads the load

by varying ARP replies based on the source MAC address of the host send-

ing the query.  Therefore it cannot balance traffic that crosses a

router, because the router itself will always be balanced to the same

virtual host.

IP balancing is not dependent on ARP and therefore also works for traffic

that comes over a router.  This method should work in all environments

and can also provide more fine grained load balancing than ARP balancing.

The downside of IP balancing is that it requires the traffic that is des-

tined towards the load balanced IP addresses to be received by all carp

hosts.  While this is always the case when connected to a hub, it has to

play some tricks in switched networks, which will result in a higher net-

work load.

A rule of thumb might be to use ARP balancing if there are many hosts on

the same network segment and to use IP balancing for all other cases.

To configure load balancing one has to specify multiple carp nodes using

the carpnodes option.  Each node in a load balancing cluster is repre-

sented by at least one “vhid:advskew” pair in a comma separated list.

carp tries to distribute the incoming network load over all configured

carpnodes.  The following example creates a load balancing group consist-

ing of three nodes, using vhids 3, 4 and 6:

# ifconfig carp0 carpnodes 3:0,4:0,6:100

The advskew value of the last node is set to 100, so that this node is

designated to the BACKUP state.  It will only become MASTER if all nodes

with a lower advskew value have failed.  By varying this value throughout

the machines in the cluster it is possible to decide which share of the

network load each node receives.  Therefore, all carp interfaces in the

cluster are configured identically, except for a different advskew value

within the carpnodes specification.

See the EXAMPLES section for a practical example of load balancing.

ARP BALANCING

For ARP balancing, one has to configure multiple carpnodes and choose the

balancing mode arp.

Once an ARP request is received, the CARP protocol will use a hashing

function against the source MAC address in the ARP request to determine

which carpnode the request belongs to.  If the corresponding carpnode is

in master state, the ARP request will be answered, otherwise it will be

ignored.

The ARP load balancing has some limitations.  Firstly, ARP balancing only

works on the local network segment.  It cannot balance traffic that

crosses a router, because the router itself will always be balanced to

the same carpnode.  Secondly, ARP load balancing can lead to asymmetric

routing of incoming and outgoing traffic, thus combining it with

pfsync(4) requires special care, because this can create a race condition

between balanced routers and the host they are serving.  ARP balancing

can be safely used with pfsync if the pf(4) ruleset translates the source

address to an unshared address on the outgoing interface using a NAT

rule.  This requires multiple CARP groups with different IP addresses on

the outgoing interface, configured so that each host is the master of one

group.

ARP balancing also works for IPv6, but instead of ARP the Neighbor Dis-

covery Protocol (NDP) is used.

IP BALANCING

IP load balancing works by utilizing the network itself to distribute in-

coming traffic to all carp nodes in the cluster.  Each packet is filtered

on the incoming carp interface so that only one node in the cluster ac-

cepts the packet.  All the other nodes will just silently drop it.  The

filtering function uses a hash over the source and destination address of

the IPv4 or IPv6 packet and compares the result against the state of the

carpnode.

IP balancing is activated by setting the balancing mode to ip.  This is

the recommended default setting.  In this mode, carp uses a multicast MAC

address, so that a switch sends incoming traffic towards all nodes.

However, there are a few OS and routers that do not accept a multicast

MAC address being mapped to a unicast IP.  This can be resolved by using

one of the following unicast options.  For scenarios where a hub is used

it is not necessary to use a multicast MAC and it is safe to use the ip-

unicast mode.  Manageable switches can usually be tricked into forwarding

unicast traffic to all cluster nodes ports by configuring them into some

sort of monitoring mode.  If this is not possible, using the ip-stealth

mode is another option, which should work on most switches.  In this mode

carp never sends packets with its virtual MAC address as source.  Stealth

mode prevents a switch from learning the virtual MAC address, so that it

has to flood the traffic to all its ports.  Please note that activating

stealth mode on a carp interface that has already been running might not

work instantly.  As a workaround the VHID of the first carpnode can be

changed to a previously unused one, or just wait until the MAC table en-

try in the switch times out.  Some Layer-3 switches do port learning

based on ARP packets.  Therefore the stealth mode cannot hide the virtual

MAC address from these kind of devices.

If IP balancing is being used on a firewall, it is recommended to config-

ure the carpnodes in a symmetrical manner.  This is achieved by simply

using the same carpnodes list on all sides of the firewall.  This ensures

that packets of one connection will pass in and out on the same host and

are not routed asymmetrically.

EXAMPLES

For firewalls and routers with multiple interfaces, it is desirable to

failover all of the carp interfaces together, when one of the physical

interfaces goes down.  This is achieved by the preempt option.  Enable it

on both host A and B:

# sysctl net.inet.carp.preempt=1

Assume that host A is the preferred master and 192.168.1.x/24 is config-

ured on one physical interface and 192.168.2.y/24 on another.  This is

the setup for host A:

# ifconfig carp0 192.168.1.1 vhid 1

# ifconfig carp1 192.168.2.1 vhid 2

The setup for host B is identical, but it has a higher advskew:

# ifconfig carp0 192.168.1.1 vhid 1 advskew 100

# ifconfig carp1 192.168.2.1 vhid 2 advskew 100

Because of the preempt option, when one of the physical interfaces of

host A fails, advskew is adjusted to 240 on all its carp interfaces.

This will cause host B to preempt on both interfaces instead of just the

failed one.

LOAD BALANCING

In order to set up a load balanced virtual host, it is necessary to con-

figure one carpnodes entry for each physical host.  In the following ex-

ample, two physical hosts are configured to provide balancing and

failover for the IP address 192.168.1.10.

First the carp interface on Host A is configured.  The advskew of 100 on

the second carpnode entry means that its advertisements will be sent out

slightly less frequently and will therefore become the designated backup.

# ifconfig carp0 192.168.1.10 carpnodes 1:0,2:100 balancing ip

The configuration for host B is identical, except the skew is on the

carpnode entry with virtual host 1 rather than virtual host 2.

# ifconfig carp0 192.168.1.10 carpnodes 1:100,2:0 balancing ip

If ARP balancing or a different mode of IP balancing is desired the

balancing mode can be adjusted accordingly.

SEE ALSO

sysctl(3), inet(4), pfsync(4), hostname.if(5), ifconfig(8), ifstated(8),

netstart(8), sysctl(8)

NAME     carp – Common Address Redundancy Protocol

SYNOPSIS     pseudo-device carp

DESCRIPTION     The carp interface is a pseudo-device which implements and controls the     CARP protocol.  carp allows multiple hosts on the same local network to     share a set of IP addresses.  Its primary purpose is to ensure that these     addresses are always available, but in some configurations carp can also     provide load balancing functionality.

A carp interface can be created at runtime using the ifconfig carpN     create command or by setting up a hostname.if(5) configuration file for     netstart(8).

To use carp, the administrator needs to configure at minimum a common     virtual host ID (VHID) and virtual host IP address on each machine which     is to take part in the virtual group.  Additional parameters can also be     set on a per-interface basis: advbase and advskew, which are used to con-     trol how frequently the host sends advertisements when it is the master     for a virtual host, and pass which is used to authenticate carp adver-     tisements.  Finally carpdev is used to specify which interface the carp     device attaches to.  If unspecified, the kernel attempts to set it by     looking for another interface with the same subnet.  These configurations     can be done using ifconfig(8), or through the SIOCSVH ioctl.

carp can also be used in conjunction with ifstated(8) to respond to     changes in CARP state; however, for most uses this will not be necessary.     See the manual page for ifstated(8) for more information.

Additionally, there are a number of global parameters which can be set     using sysctl(8):

net.inet.carp.allow         Accept incoming carp packets.  Enabled by de-                                 fault.

net.inet.carp.preempt       Allow virtual hosts to preempt each other.                                 It is also used to failover carp interfaces                                 as a group.  When the option is enabled and                                 one of the carp enabled physical interfaces                                 goes down, advskew is changed to 240 on all                                 carp interfaces.  See also the first example.                                 Disabled by default.

net.inet.carp.log           Make carp log state changes, bad packets, and                                 other errors.  May be a value between 0 and 7                                 corresponding with syslog(3) priorities.  The                                 default value is 2, which limits logging to                                 changes in CARP state.

LOAD BALANCING     carp provides two mechanisms to load balance incoming traffic over a     group of carp hosts: ARP balancing and IP balancing.

Which one to use mainly depends on the network environment carp is being     used in.  ARP balancing has limited abilities for load balancing the in-     coming connections between hosts in an Ethernet network.  It only works     for clients in the local network, because ARP balancing spreads the load     by varying ARP replies based on the source MAC address of the host send-     ing the query.  Therefore it cannot balance traffic that crosses a     router, because the router itself will always be balanced to the same     virtual host.

IP balancing is not dependent on ARP and therefore also works for traffic     that comes over a router.  This method should work in all environments     and can also provide more fine grained load balancing than ARP balancing.     The downside of IP balancing is that it requires the traffic that is des-     tined towards the load balanced IP addresses to be received by all carp     hosts.  While this is always the case when connected to a hub, it has to     play some tricks in switched networks, which will result in a higher net-     work load.

A rule of thumb might be to use ARP balancing if there are many hosts on     the same network segment and to use IP balancing for all other cases.

To configure load balancing one has to specify multiple carp nodes using     the carpnodes option.  Each node in a load balancing cluster is repre-     sented by at least one “vhid:advskew” pair in a comma separated list.     carp tries to distribute the incoming network load over all configured     carpnodes.  The following example creates a load balancing group consist-     ing of three nodes, using vhids 3, 4 and 6:

# ifconfig carp0 carpnodes 3:0,4:0,6:100

The advskew value of the last node is set to 100, so that this node is     designated to the BACKUP state.  It will only become MASTER if all nodes     with a lower advskew value have failed.  By varying this value throughout     the machines in the cluster it is possible to decide which share of the     network load each node receives.  Therefore, all carp interfaces in the     cluster are configured identically, except for a different advskew value     within the carpnodes specification.

See the EXAMPLES section for a practical example of load balancing.

ARP BALANCING     For ARP balancing, one has to configure multiple carpnodes and choose the     balancing mode arp.

Once an ARP request is received, the CARP protocol will use a hashing     function against the source MAC address in the ARP request to determine     which carpnode the request belongs to.  If the corresponding carpnode is     in master state, the ARP request will be answered, otherwise it will be     ignored.

The ARP load balancing has some limitations.  Firstly, ARP balancing only     works on the local network segment.  It cannot balance traffic that     crosses a router, because the router itself will always be balanced to     the same carpnode.  Secondly, ARP load balancing can lead to asymmetric     routing of incoming and outgoing traffic, thus combining it with     pfsync(4) requires special care, because this can create a race condition     between balanced routers and the host they are serving.  ARP balancing     can be safely used with pfsync if the pf(4) ruleset translates the source     address to an unshared address on the outgoing interface using a NAT     rule.  This requires multiple CARP groups with different IP addresses on     the outgoing interface, configured so that each host is the master of one     group.

ARP balancing also works for IPv6, but instead of ARP the Neighbor Dis-     covery Protocol (NDP) is used.

IP BALANCING     IP load balancing works by utilizing the network itself to distribute in-     coming traffic to all carp nodes in the cluster.  Each packet is filtered     on the incoming carp interface so that only one node in the cluster ac-     cepts the packet.  All the other nodes will just silently drop it.  The     filtering function uses a hash over the source and destination address of     the IPv4 or IPv6 packet and compares the result against the state of the     carpnode.

IP balancing is activated by setting the balancing mode to ip.  This is     the recommended default setting.  In this mode, carp uses a multicast MAC     address, so that a switch sends incoming traffic towards all nodes.

However, there are a few OS and routers that do not accept a multicast     MAC address being mapped to a unicast IP.  This can be resolved by using     one of the following unicast options.  For scenarios where a hub is used     it is not necessary to use a multicast MAC and it is safe to use the ip-     unicast mode.  Manageable switches can usually be tricked into forwarding     unicast traffic to all cluster nodes ports by configuring them into some     sort of monitoring mode.  If this is not possible, using the ip-stealth     mode is another option, which should work on most switches.  In this mode     carp never sends packets with its virtual MAC address as source.  Stealth     mode prevents a switch from learning the virtual MAC address, so that it     has to flood the traffic to all its ports.  Please note that activating     stealth mode on a carp interface that has already been running might not     work instantly.  As a workaround the VHID of the first carpnode can be     changed to a previously unused one, or just wait until the MAC table en-     try in the switch times out.  Some Layer-3 switches do port learning     based on ARP packets.  Therefore the stealth mode cannot hide the virtual     MAC address from these kind of devices.

If IP balancing is being used on a firewall, it is recommended to config-     ure the carpnodes in a symmetrical manner.  This is achieved by simply     using the same carpnodes list on all sides of the firewall.  This ensures     that packets of one connection will pass in and out on the same host and     are not routed asymmetrically.

EXAMPLES     For firewalls and routers with multiple interfaces, it is desirable to     failover all of the carp interfaces together, when one of the physical     interfaces goes down.  This is achieved by the preempt option.  Enable it     on both host A and B:

# sysctl net.inet.carp.preempt=1

Assume that host A is the preferred master and 192.168.1.x/24 is config-     ured on one physical interface and 192.168.2.y/24 on another.  This is     the setup for host A:

# ifconfig carp0 192.168.1.1 vhid 1           # ifconfig carp1 192.168.2.1 vhid 2

The setup for host B is identical, but it has a higher advskew:

# ifconfig carp0 192.168.1.1 vhid 1 advskew 100           # ifconfig carp1 192.168.2.1 vhid 2 advskew 100

Because of the preempt option, when one of the physical interfaces of     host A fails, advskew is adjusted to 240 on all its carp interfaces.     This will cause host B to preempt on both interfaces instead of just the     failed one.

LOAD BALANCING     In order to set up a load balanced virtual host, it is necessary to con-     figure one carpnodes entry for each physical host.  In the following ex-     ample, two physical hosts are configured to provide balancing and     failover for the IP address 192.168.1.10.

First the carp interface on Host A is configured.  The advskew of 100 on     the second carpnode entry means that its advertisements will be sent out     slightly less frequently and will therefore become the designated backup.

# ifconfig carp0 192.168.1.10 carpnodes 1:0,2:100 balancing ip

The configuration for host B is identical, except the skew is on the     carpnode entry with virtual host 1 rather than virtual host 2.

# ifconfig carp0 192.168.1.10 carpnodes 1:100,2:0 balancing ip

If ARP balancing or a different mode of IP balancing is desired the     balancing mode can be adjusted accordingly.

SEE ALSO     sysctl(3), inet(4), pfsync(4), hostname.if(5), ifconfig(8), ifstated(8),     netstart(8), sysctl(8)

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
2月前
|
人工智能 API 网络安全
新手零基础阿里云轻量服务器部署OpenClaw、集成iMessage简单步骤及免费大模型百炼Coding Plan API配置及避坑指南
OpenClaw(又名Clawdbot,常被称为AI小龙虾)是一款开源、轻量、可高度自定义的AI自动化网关工具,能一键集成iMessage、飞书、Slack等主流IM平台,通过对接大模型API实现智能对话、任务自动化、代码生成等核心能力。对于新手而言,**阿里云轻量应用服务器**凭借低成本、高稳定性、一键应用镜像、免复杂环境配置的特性,成为部署OpenClaw的最优选择。搭配阿里云百炼Coding Plan免费额度,无需额外付费即可搭建7×24小时稳定运行的专属AI服务,本文将从服务器选购、OpenClaw部署、iMessage集成、百炼API配置到高频问题避坑,提供全流程零基础可直接复制
496 6
|
存储 监控 安全
网络安全视角:从地域到账号的阿里云日志审计实践
日志审计的必要性在于其能够帮助企业和组织落实法律要求,打破信息孤岛和应对安全威胁。选择 SLS 下日志审计应用,一方面是选择国家网络安全专用认证的日志分析产品,另一方面可以快速帮助大型公司统一管理多组地域、多个账号的日志数据。除了在日志服务中存储、查看和分析日志外,还可通过报表分析和告警配置,主动发现潜在的安全威胁,增强云上资产安全。
1503 79
|
11月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
500 83
|
供应链 监控 搜索推荐
企业销售管理利器:销售易、飞鱼和800客CRM深度解析
- **销售易**:集营销、销售和服务于一体,提供全渠道获客、潜客识别、线索转化等功能,适合中大型企业,尤其适用于快消品、汽车等行业。 - **飞鱼**:由巨量引擎推出,专注于广告主的销售线索管理,实现自动获取、同步及跟进,适合各类规模企业,广泛应用于电商、金融等领域。 - **800客**:功能全面,涵盖市场、客户、销售、服务等管理模块,适合中小型到大型企业,提供定制化服务,满足个性化需求。 通过对比各产品的功能与适用场景,企业可根据自身需求选择最合适的CRM解决方案,以优化销售流程并深化客户关系。
|
12月前
|
监控 数据挖掘 API
淘宝API系列:淘宝商品详情接口详解
淘宝商品详情接口是淘宝开放平台的核心服务之一,支持开发者通过编程获取商品的标题、价格、销量、描述、图片、视频及SKU信息。广泛应用于电商数据分析、价格监控、竞品分析和自动化工具开发,助力企业提升运营效率与市场竞争力。
|
数据安全/隐私保护 SoC
基于PI控制的三相整流器控制系统的simulink建模与仿真,包含超级电容充电和电机
本课题基于MATLAB 2022a的Simulink平台,构建了PI控制的三相整流器控制系统,用于PMSM电机发电并为超级电容充电。系统通过调节电流和电压,实现高效能量管理和动力输出。核心模块包括三相整流器、超级电容及其显示模块、PI控制器。仿真结果无水印,完整展示了系统性能。系统原理涵盖交流转直流、超级电容快速充放电及电机驱动,适用于多种工况下的能量管理。
|
机器学习/深度学习 人工智能 自然语言处理
AI 世界生存手册(二):从LR到DeepSeek,模型慢慢变大了,也变强了
大家都可以通过写 prompt 来和大模型对话,那大模型之前的算法是怎样的,算法世界经过了哪些比较关键的发展,最后为什么是大模型这条路线走向了 AGI,作者用两篇文章共5.7万字详细探索一下。 第一篇文章指路👉《AI 世界生存手册(一):从LR到DeepSeek,模型慢慢变大了,也变强了》
AI 世界生存手册(二):从LR到DeepSeek,模型慢慢变大了,也变强了
|
机器学习/深度学习 算法 数据挖掘
【Python机器学习专栏】层次聚类算法的原理与应用
【4月更文挑战第30天】层次聚类是数据挖掘中的聚类技术,无需预设簇数量,能生成数据的层次结构。分为凝聚(自下而上)和分裂(自上而下)两类,常用凝聚层次聚类有最短/最长距离、群集平均和Ward方法。优点是自动确定簇数、提供层次结构,适合小到中型数据集;缺点是计算成本高、过程不可逆且对异常值敏感。在Python中可使用`scipy.cluster.hierarchy`进行实现。尽管有局限,层次聚类仍是各领域强大的分析工具。
1239 3
|
弹性计算 Java 数据库
基于ECS使用Halo实现博客平台
基于ECS使用Halo实现博客平台,快速的搭建一个可用的动态博客平台
1003 2
基于ECS使用Halo实现博客平台
|
Oracle IDE Java
从Java8到Java17
背景Java8的前世今生作为一名程序员,笔者从大学开始接触Java这门编程语言,还记得当时的版本是1.4,不过这个版本的寿命还挺长,目前在一些金融行业的存量系统中依然还有1.4版本的影子。从C/C++到Java,Java给我的第一印象,就是这门语言的语法非常之啰嗦,比如内部类,像下面这段排序的代码,在C语言里面可以很方便地通过函数指针来解决,C++可以通过运算符重载来解决,唯独Java语言的写法最
从Java8到Java17

热门文章

最新文章