百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Linux双网卡打流(1)_linux双网卡bond

nanshan 2025-02-20 17:09 21 浏览 0 评论

同一机器上实现双网卡打流,在linux下直接使用iperf打流,数据流不会经过两个网卡TX&RX回来的,这个测试的数据是不对的。

有两种方法可以解决这个问题:

第一种是通过iptables、ip、route配置路由转发,今天就讲这个

第二种是通过网络命名空间隔离,下篇讲

这里不涉及到网卡性能调优,下下篇讲


网络拓扑

双向同时收发

iperf <-> CPU eth1 <->
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
 iperf <-> CPU eth2 <->


主要脚本

TEST_IFACE=(eth60 eth61)
ETH1_DEV="${TEST_IFACE[0]}"
ETH2_DEV="${TEST_IFACE[1]}"
IFACE_IP=(192.168.100.1 192.168.101.1)
IFACE_FAKE_IP=(192.168.102.1 192.168.103.1)

eth1_mac=$(ifconfig "$ETH1_DEV"|grep -i "ether" |awk '{print $2}')
eth2_mac=$(ifconfig "$ETH2_DEV"|grep -i "ether" |awk '{print $2}')
eth1_ip="${IFACE_IP[0]}"
eth2_ip="${IFACE_IP[1]}"
eth1_fake_ip="${IFACE_FAKE_IP[0]}"
eth2_fake_ip="${IFACE_FAKE_IP[1]}"
ifconfig "$ETH1_DEV" "$eth1_ip/24" up
ifconfig "$ETH2_DEV" "$eth2_ip/24" up

ip -s -s neigh flush all
iptables -t nat -F

iptables -t nat -A POSTROUTING -s "$eth1_ip" -d "$eth2_fake_ip" -j SNAT --to-source "$eth1_fake_ip"
iptables -t nat -A PREROUTING -d "$eth1_fake_ip" -j DNAT --to-destination "$eth1_ip"

iptables -t nat -A POSTROUTING -s "$eth2_ip" -d "$eth1_fake_ip" -j SNAT --to-source "$eth2_fake_ip"
iptables -t nat -A PREROUTING -d "$eth2_fake_ip" -j DNAT --to-destination "$eth2_ip"

ip route add "$eth2_fake_ip" dev "$ETH1_DEV"
arp -i "$ETH1_DEV" -s "$eth2_fake_ip" "$eth2_mac"

ip route add "$eth1_fake_ip" dev "$ETH2_DEV"
arp -i "$ETH2_DEV" -s "$eth1_fake_ip" "$eth1_mac"

iperf -B $eth2_ip -s"
iperf -B $eth1_ip -s"

iperf -B "$eth1_ip" -c "$eth2_fake_ip" -t 60 -i 2 -P 2"
iperf -B "$eth2_ip" -c "$eth1_fake_ip" -t 60 -i 2 -P 2"


iptables设置SNAT和DNAT的转换的作用是什么

iptables设置SNAT(Source Network Address Translation)和DNAT(Destination Network Address Translation)转换的作用是在网络数据包经过防火墙或路由器时,对数据包的源地址和目标地址进行转换,以实现网络地址的隐藏、伪装、转发等功能。


SNAT(源地址转换)

当数据包从内部网络发送到外部网络时,防火墙或路由器可以使用SNAT将内部主机的私有IP地址转换为公共IP地址,以隐藏内部网络的真实结构。

例如:假设内部主机的私有IP地址为192.168.1.100,而防火墙的公共IP地址为203.0.113.10,可以使用以下iptables规则进行SNAT转换

iptables -t nat -A POSTROUTING -s 192.168.1.100 -j SNAT --to-source 203.0.113.10


DNAT(目标地址转换)

当数据包从外部网络发送到内部网络时,防火墙或路由器可以使用DNAT将外部发送的数据包目标地址转换为内部网络中的主机地址,以实现端口映射、服务转发等功能。

例如:假设防火墙的公共IP地址为203.0.113.10,需要将外部访问该IP的HTTP流量转发到内部主机192.168.1.200的HTTP服务上,可以使用以下iptables规则进行DNAT转换

iptables -t nat -A PREROUTING -d 203.0.113.10 -p tcp --dport 80 -j DNAT --to-destination 192.168.1.200:80


ip route add的作用是什么?

例如:路由表中添加一条路由规则,将目的网络192.168.10.0/24的数据包发送到网关192.168.1.1,通过网卡eth0进行传输

ip route add 192.168.10.0/24 via 192.168.1.1 dev eth0


arp的作用?

ARP(Address Resolution Protocol)的作用是将IP地址映射到MAC地址,以便在局域网中正确路由数据包。ARP协议用于解决网络设备在发送数据包时需要知道目标设备的MAC地址的问题,通过广播ARP请求获取目标设备的MAC地址,从而建立IP地址与MAC地址的映射关系。

例子:

假设有一台主机A(IP地址为192.168.1.100)要与另一台主机B(IP地址为192.168.1.200)进行通信,但主机A只知道目标主机B的IP地址,不知道其MAC地址。

ARP请求

主机A向局域网内广播一个ARP请求,谁知道IP地址192.168.1.200的MAC地址?

所有收到这个ARP请求的设备都会检查目标IP地址,如果是自己的IP地址,则会回复包含自己的MAC地址的ARP响应。

ARP响应

主机B收到ARP请求后,会回复一个ARP响应,包含自己的MAC地址。

主机A收到ARP响应后,就知道了主机B的MAC地址,可以将数据包发送到目标主机B。


设置步骤

第一步:

iptables -t nat -A POSTROUTING -s "$eth1_ip" -d "$eth2_fake_ip" -j SNAT --to-source "$eth1_fake_ip"

流量从eth1_ip(eth1网卡的IP地址)发出,目的地址为eth2_fake_ip时,对源地址转换(SNAT),源地址将被转换为eth1_fake_ip


第二步:

iptables -t nat -A PREROUTING -d "$eth1_fake_ip" -j DNAT --to-destination "$eth1_ip"

流量到达主机并且目的地址为eth1_fake_ip时,对流量进行目标地址转换(DNAT)。目的地址将被转换为eth1_ip(eth1网卡的实际IP地址)


第三步:

iptables -t nat -A POSTROUTING -s "$eth2_ip" -d "$eth1_fake_ip" -j SNAT --to-source "$eth2_fake_ip"

流量从eth2_ip(eth2网卡的IP地址)发出,目的地址为eth1_fake_ip时,对流量进行源地址转换(SNAT),源地址将被转换为$eth2_fake_ip


第四步:

iptables -t nat -A PREROUTING -d "$eth2_fake_ip" -j DNAT --to-destination "$eth2_ip"

流量到达主机并且目的地址为eth2_fake_ip时,对流量进行目标地址转换(DNAT),目的地址将被转换为eth2_ip(eth2网卡的实际IP地址)。


第五步:

ip route add "$eth2_fake_ip" dev "$ETH1_DEV"

将目标IP地址eth2_fake_ip添加到路由表中,指定通过网卡$ETH1_DEV发送流量。


第六步:

arp -i "$ETH1_DEV" -s "$eth2_fake_ip" "$eth2_mac"

在ARP表中添加一条静态ARP表项,将IP地址eth2_fake_ip映射到MAC地址eth2_mac。


第七步:

ip route add "$eth1_fake_ip" dev "$ETH2_DEV"

将目标IP地址eth1_fake_ip添加到路由表中,指定通过网卡ETH2_DEV发送流量。


第八步:

arp -i "$ETH2_DEV" -s "$eth1_fake_ip" "$eth1_mac"

在ARP表中添加一条静态ARP表项,将IP地址eth1_fake_ip映射到MAC地址eth1_mac。

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: