mirror of
https://github.com/yggdrasil-network/yggdrasil-go.git
synced 2025-01-03 21:57:45 +00:00
commit
45224d5f10
33
misc/run-twolink-test
Executable file
33
misc/run-twolink-test
Executable file
@ -0,0 +1,33 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Connects nodes in two namespaces by two links with different bandwidth (10mbit and 100mbit)
|
||||||
|
|
||||||
|
ip netns add node1
|
||||||
|
ip netns add node2
|
||||||
|
|
||||||
|
ip link add veth11 type veth peer name veth21
|
||||||
|
ip link set veth11 netns node1 up
|
||||||
|
ip link set veth21 netns node2 up
|
||||||
|
|
||||||
|
ip link add veth12 type veth peer name veth22
|
||||||
|
ip link set veth12 netns node1 up
|
||||||
|
ip link set veth22 netns node2 up
|
||||||
|
|
||||||
|
ip netns exec node1 tc qdisc add dev veth11 root tbf rate 10mbit burst 8192 latency 1ms
|
||||||
|
ip netns exec node2 tc qdisc add dev veth21 root tbf rate 10mbit burst 8192 latency 1ms
|
||||||
|
|
||||||
|
ip netns exec node1 tc qdisc add dev veth12 root tbf rate 100mbit burst 8192 latency 1ms
|
||||||
|
ip netns exec node2 tc qdisc add dev veth22 root tbf rate 100mbit burst 8192 latency 1ms
|
||||||
|
|
||||||
|
echo '{AdminListen: "unix://node1.sock"}' | ip netns exec node1 env PPROFLISTEN=localhost:6060 ./yggdrasil -logging "info,warn,error,debug" -useconf &> node1.log &
|
||||||
|
echo '{AdminListen: "unix://node2.sock"}' | ip netns exec node2 env PPROFLISTEN=localhost:6060 ./yggdrasil -logging "info,warn,error,debug" -useconf &> node2.log &
|
||||||
|
|
||||||
|
echo "Started, to continue you should (possibly w/ sudo):"
|
||||||
|
echo "kill" $(jobs -p)
|
||||||
|
wait
|
||||||
|
|
||||||
|
ip netns delete node1
|
||||||
|
ip netns delete node2
|
||||||
|
|
||||||
|
ip link delete veth11
|
||||||
|
ip link delete veth12
|
@ -216,6 +216,8 @@ func (intf *linkInterface) handler() error {
|
|||||||
case signalReady <- struct{}{}:
|
case signalReady <- struct{}{}:
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
|
intf.link.core.log.Debugf("Sending packet to %s: %s, source %s",
|
||||||
|
strings.ToUpper(intf.info.linkType), themString, intf.info.local)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
@ -235,18 +237,21 @@ func (intf *linkInterface) handler() error {
|
|||||||
recvTimer := time.NewTimer(recvTime)
|
recvTimer := time.NewTimer(recvTime)
|
||||||
defer util.TimerStop(recvTimer)
|
defer util.TimerStop(recvTimer)
|
||||||
for {
|
for {
|
||||||
|
intf.link.core.log.Debugf("State of %s: %s, source %s :: isAlive %t isReady %t sendTimerRunning %t recvTimerRunning %t",
|
||||||
|
strings.ToUpper(intf.info.linkType), themString, intf.info.local,
|
||||||
|
isAlive, isReady, sendTimerRunning, recvTimerRunning)
|
||||||
select {
|
select {
|
||||||
case gotMsg, ok := <-signalAlive:
|
case gotMsg, ok := <-signalAlive:
|
||||||
if !ok {
|
if !ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !isAlive {
|
util.TimerStop(recvTimer)
|
||||||
isAlive = true
|
recvTimerRunning = false
|
||||||
if !isReady {
|
isAlive = true
|
||||||
// (Re-)enable in the switch
|
if !isReady {
|
||||||
isReady = true
|
// (Re-)enable in the switch
|
||||||
intf.link.core.switchTable.idleIn <- intf.peer.port
|
intf.link.core.switchTable.idleIn <- intf.peer.port
|
||||||
}
|
isReady = true
|
||||||
}
|
}
|
||||||
if gotMsg && !sendTimerRunning {
|
if gotMsg && !sendTimerRunning {
|
||||||
// We got a message
|
// We got a message
|
||||||
@ -255,6 +260,10 @@ func (intf *linkInterface) handler() error {
|
|||||||
sendTimer.Reset(sendTime)
|
sendTimer.Reset(sendTime)
|
||||||
sendTimerRunning = true
|
sendTimerRunning = true
|
||||||
}
|
}
|
||||||
|
if !gotMsg {
|
||||||
|
intf.link.core.log.Debugf("Received ack from %s: %s, source %s",
|
||||||
|
strings.ToUpper(intf.info.linkType), themString, intf.info.local)
|
||||||
|
}
|
||||||
case sentMsg, ok := <-signalSent:
|
case sentMsg, ok := <-signalSent:
|
||||||
// Stop any running ack timer
|
// Stop any running ack timer
|
||||||
if !ok {
|
if !ok {
|
||||||
@ -273,12 +282,13 @@ func (intf *linkInterface) handler() error {
|
|||||||
if !ok {
|
if !ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !isAlive || !isReady {
|
if !isAlive {
|
||||||
// Disable in the switch
|
// Disable in the switch
|
||||||
isReady = false
|
isReady = false
|
||||||
} else {
|
} else {
|
||||||
// Keep enabled in the switch
|
// Keep enabled in the switch
|
||||||
intf.link.core.switchTable.idleIn <- intf.peer.port
|
intf.link.core.switchTable.idleIn <- intf.peer.port
|
||||||
|
isReady = true
|
||||||
}
|
}
|
||||||
case <-sendTimer.C:
|
case <-sendTimer.C:
|
||||||
// We haven't sent anything, so signal a send of a 0 packet to let them know we're alive
|
// We haven't sent anything, so signal a send of a 0 packet to let them know we're alive
|
||||||
|
@ -780,6 +780,7 @@ func (t *switchTable) doWorker() {
|
|||||||
t.queues.bufs = make(map[string]switch_buffer) // Packets per PacketStreamID (string)
|
t.queues.bufs = make(map[string]switch_buffer) // Packets per PacketStreamID (string)
|
||||||
idle := make(map[switchPort]struct{}) // this is to deduplicate things
|
idle := make(map[switchPort]struct{}) // this is to deduplicate things
|
||||||
for {
|
for {
|
||||||
|
t.core.log.Debugf("Switch state: idle = %d, buffers = %d", len(idle), len(t.queues.bufs))
|
||||||
select {
|
select {
|
||||||
case bytes := <-t.packetIn:
|
case bytes := <-t.packetIn:
|
||||||
// Try to send it somewhere (or drop it if it's corrupt or at a dead end)
|
// Try to send it somewhere (or drop it if it's corrupt or at a dead end)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user