UML 和 ethertap:我想念什么?

UML 和 ethertap:我想念什么?

我想通过网络运行我的 UML istance 在主机中我创建了脚本

USER=myname
BRIDGENAME=br0
tunctl -t tap0 -u $USER
ip link set tap0 up
/usr/sbin/brctl addif $BRIDGENAME tap0
ip addr add 10.2.0.5/24 dev tap0

tap0创建完毕,没有报错。之后我启动 uml istance

/usr/bin/linux ubda=fsroot mem=1024M con0=fd:0,fd:1 con=pts eth0=ethertap,tap0,10.2.0.5

然后我用 minicom 输入 uml istance 并尝试配置网络

ip addr add 10.2.0.6/24 dev eth0
ip route add default via 10.2.0.5
Error: Nexthop has invalid gateway.

我想念什么?为什么不沟通呢?我也尝试过使用经典的 iptables 规则进行 natting

echo 1 > /proc/sys/net/ipv4/ip_forward
iptables -A FORWARD -i tap0 -o br0 -j ACCEPT
iptables -A FORWARD -i br0 -o tap0 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT 
iptables -t nat -A POSTROUTING -o br0 -j MASQUERADE

但没有任何改变。

答案1

找到解决方案,在 UML 的配置中我忘记了这一行

ip link set eth0 up

路线之前

我还改变了方法,使用enp1s0代替bridge,使用ethertune代替ethertap

a)首先我创建tap0

sudo ip tuntap add tap0 mode tap
sudo ip addr add 10.2.0.5/24 dev tap0
ip link set tap0 up

b)然后我应用 iptables 规则

iptables -A FORWARD -i tap0 -o enp1s0 -j ACCEPT
iptables -A FORWARD -i enp1s0  -o tap0 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT 
iptables -t nat -A POSTROUTING -o enp1s0 -j MASQUERADE

c)最后运行实例

linux ubda=fsroot mem=1024M con0=fd:0,fd:1 con=pts eth0=tuntap,tap0,10.2.0.5

d)在我配置网络的情况下

ip addr add 10.2.0.6/24
ip link set eth0 up
ip route add default via 10.2.0.5

工作正常

相关内容