从 Unetstack 中的路由 table 中删除路由
Deleting a route from routing table in Unetstack
我在 UnetStack 中仅从代理创建我的路由,没有任何 shellcode。我想从路由 table?
中删除一条路由
以下是我的代码:
我想做的是每 10 秒在两条路线之间切换一次。因此,从我的源节点(节点 5)到我的目标节点(节点 1),路线从 5 到 3 到 4 到 1 或者从 5 到 2 到 4 到 1
模拟
platform = RealTimePlatform
channel.model = ProtocolChannelModel
channel.soundSpeed = 1500.mps // c
channel.communicationRange = 100.m // Rc
// run the simulation infinately
simulate {
// Destination node
node '1', remote: 1101, address: 1, location: [ 0.m, 0.m, 0.m], shell: 5101, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
node '2', remote: 1102, address: 2, location: [ 0.m, 0.m, -75.m], shell: 5102, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
// neighbor node for node 5, and will be a next node for node 5 during routing
node '3', remote: 1103, address: 3, location: [0.m, 0.m, -90.m], shell: 5103, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
//Neighbor node for node 5 ,but not a next node for node 5
node '4', remote: 1104, address: 4, location: [0.m, 0.m, -150.m], shell: 5104, stack: {container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
// Source node
node '5', remote: 1105, address: 5, location: [0.m, 0.m, -160.m], shell: true, stack: {container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
}
代理
class new_routing_agent extends UnetAgent {
def router
int addr
def flag
void addroute(int to, int via) {
router.send new RouteDiscoveryNtf(to: to, nextHop: via)
}
void deleteRoutes(){
// router.send new RouteDiscoveryNtf().setRoute()
}
void routeDynamically(){
while(1){
deleteRoutes()
if(flag){
addroute 1, 2
}
else{
addroute 1,3
}
flag = !flag
sleep(10000)
}
}
void startup() {
flag = false
def phy = agentForService Services.PHYSICAL
subscribe topic(phy)
router = agentForService Services.ROUTING
subscribe topic(router)
def nodeInfo = agentForService Services.NODE_INFO
addr = nodeInfo.address
switch (addr){
case 1:
addroute 1, 1
break
case 2:
addroute 1, 4
break
case 3:
addroute 1, 4
break
case 4:
addroute 1, 1
break
case 5:
routeDynamically()
break
default:
addroute 1, 1
break
}
}
void processMessage(Message msg) {
}
}
UnetStack 目前没有将删除路由的消息标准化为 ROUTING 服务的一部分。但是,您可以使用与 shell 相同的机制来删除路由,请记住 UnetStack 的未来版本可能会更改该机制。有关如何执行此操作的详细信息,请参阅:How to delete route entries from routing table using an agent in UnetStack.
我在 UnetStack 中仅从代理创建我的路由,没有任何 shellcode。我想从路由 table?
中删除一条路由以下是我的代码:
我想做的是每 10 秒在两条路线之间切换一次。因此,从我的源节点(节点 5)到我的目标节点(节点 1),路线从 5 到 3 到 4 到 1 或者从 5 到 2 到 4 到 1
模拟
platform = RealTimePlatform
channel.model = ProtocolChannelModel
channel.soundSpeed = 1500.mps // c
channel.communicationRange = 100.m // Rc
// run the simulation infinately
simulate {
// Destination node
node '1', remote: 1101, address: 1, location: [ 0.m, 0.m, 0.m], shell: 5101, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
node '2', remote: 1102, address: 2, location: [ 0.m, 0.m, -75.m], shell: 5102, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
// neighbor node for node 5, and will be a next node for node 5 during routing
node '3', remote: 1103, address: 3, location: [0.m, 0.m, -90.m], shell: 5103, stack: { container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
//Neighbor node for node 5 ,but not a next node for node 5
node '4', remote: 1104, address: 4, location: [0.m, 0.m, -150.m], shell: 5104, stack: {container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
// Source node
node '5', remote: 1105, address: 5, location: [0.m, 0.m, -160.m], shell: true, stack: {container ->
container.add 'new_routing_agent', new new_routing_agent();
container.add 'routing', new Router();
container.add 'rdp', new RouteDiscoveryProtocol();
}
}
代理
class new_routing_agent extends UnetAgent {
def router
int addr
def flag
void addroute(int to, int via) {
router.send new RouteDiscoveryNtf(to: to, nextHop: via)
}
void deleteRoutes(){
// router.send new RouteDiscoveryNtf().setRoute()
}
void routeDynamically(){
while(1){
deleteRoutes()
if(flag){
addroute 1, 2
}
else{
addroute 1,3
}
flag = !flag
sleep(10000)
}
}
void startup() {
flag = false
def phy = agentForService Services.PHYSICAL
subscribe topic(phy)
router = agentForService Services.ROUTING
subscribe topic(router)
def nodeInfo = agentForService Services.NODE_INFO
addr = nodeInfo.address
switch (addr){
case 1:
addroute 1, 1
break
case 2:
addroute 1, 4
break
case 3:
addroute 1, 4
break
case 4:
addroute 1, 1
break
case 5:
routeDynamically()
break
default:
addroute 1, 1
break
}
}
void processMessage(Message msg) {
}
}
UnetStack 目前没有将删除路由的消息标准化为 ROUTING 服务的一部分。但是,您可以使用与 shell 相同的机制来删除路由,请记住 UnetStack 的未来版本可能会更改该机制。有关如何执行此操作的详细信息,请参阅:How to delete route entries from routing table using an agent in UnetStack.