bash - 什么可以防止频繁切换具有多个接口(interface)的机器的默认源 ip

标签 bash routing tcp iproute

目标是在具有多个接口(interface)和实时 ip 的机器上频繁更改默认传出源 ip。

我根据其文档使用 ip route replace default 并让脚本循环运行一段时间。它会在一段时间内很好地更改源 IP,但随后所有对机器的互联网访问都将丢失。它必须从网络界面远程重启才能正常工作

有什么东西可能会阻止它稳定工作吗?我在不止一台服务器上试过这个吗?

下面是一个最小的例子

# extract all currently active source ips except loopback
IPs="$(ifconfig  | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 |
awk '{ print $1}')"

read -a ip_arr <<<$IPs

# extract all currently active mac / ethernet addresses
Int="$(ifconfig  | grep 'eth'| grep -v 'lo' | awk '{print $1}')"
read -a eth_arr <<<$Int

ip_len=${#ip_arr[@]}
eth_len=${#eth_arr[@]}

i=0;
e=0;

while(true); do

    #ip route replace 0.0.0.0 dev eth0:1 src 192.168.1.18
    route_cmd="ip route replace 0.0.0.0 dev ${eth_arr[e]} src ${ip_arr[i]}"
    echo $route_cmd
    eval $route_cmd

    sleep 300

    (i++)
    (e++)

    if [ $i -eq $ip_len ]; then
        i=0;
        e=0;
        echo "all ips exhausted - starting from first again"
    #   break;
    fi

done

最佳答案

我想发表评论,但由于我没有足够的积分,所以不允许我发表评论。

考虑:

  • 在再次运行之前改变延迟时间是否会改变失败之前的迭代次数?
  • 每次更改时导出 ifconfig 和路由,以查看随着时间的推移是否有明显不同。也许对它进行一些基本测试(ping、nslookup 等)基本上,找到它究竟出了什么问题。还将您发送的命令导出到日志文件(每次更改的文本文件?)以查看其中的更改,看看在 x 次迭代后是否有些不同。
  • 什么连接丢失了?传入?外向?具体应用?
  • 你说你在其他服务器上使用/执行此操作没有问题?
  • IP 是:静态(/etc/network/interfaces)、bootp/DHCP、半静态(bootp/DHCP 服务器服务,基于 MAC 地址),如果由 bootp/DHCP 提供服务,租期是多少?

关于最后一句话: bootp/dhcp 将提供 x 持续时间的 IP。说是60分钟。一半时间后,它将“检查”bootp/dhcp 服务器是否可以保留 IP,并再次将租约延长至 60 分钟,这可能意味着在 ifconfig 上进行小的重新配置(甚至可能在您的脚本的同一时间?)。

第一个

关于bash - 什么可以防止频繁切换具有多个接口(interface)的机器的默认源 ip,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30810925/

相关文章:

bash - 使用 && 和 || 时无法停止 BASH运营商

symfony - 同 bundle 不同路线

symfony - FOSRestBundle 2.4 |如何加载休息型路线

sockets - 套接字编程客户端连接

java - 在 Java 中通过 TCP 发送 ArrayList<String[]> 的最佳方式?

bash - 使用 `at` 进行作业调度。 "EOF: not found"

bash - 在密码提示时立即向 SSH 发送关闭信号

bash - 导出 `/bin/bash -c` 内的变量

Angular 2 - 子路由加载父组件

java - 如何将字节数组发送到特定接收者