129 lines
5.7 KiB
Python
129 lines
5.7 KiB
Python
from core.topo import TopoParameter
|
|
from .multi_interface import MultiInterfaceTopo, MultiInterfaceConfig
|
|
import logging
|
|
|
|
|
|
class IoTMultiClientTopo(MultiInterfaceTopo):
|
|
NAME = "IoTMultiClient"
|
|
|
|
def __init__(self, topo_builder, parameterFile):
|
|
logging.info("Initializing IoTMultiClientTopo...")
|
|
super(IoTMultiClientTopo, self).__init__(
|
|
topo_builder, parameterFile)
|
|
|
|
for i in range(self.topo_parameter.clients):
|
|
# For each client-router, add a client, a bottleneck link, and a server
|
|
self.add_client_with_link()
|
|
|
|
# And connect the router to all servers
|
|
# for s in self.servers[1:]:
|
|
# self.add_link(self.router, s)
|
|
|
|
def add_client_with_link(self):
|
|
client = self.add_client()
|
|
for bl in self.c2r_links:
|
|
self.add_link(client, bl.get_left())
|
|
|
|
def __str__(self):
|
|
s = "IoT Multiple interface topology with several clients and servers\n"
|
|
# i = 0
|
|
# nc = len(self.get_client_to_router_links())
|
|
# for i in range(0, nc):
|
|
# if i == nc // 2:
|
|
# s = s + "c- r--s\n"
|
|
# s = s + "c-\sw---bl---sw-/ \-s\n"
|
|
# else:
|
|
# s = s + "c-/sw---bl---sw-\ /-s\n"
|
|
|
|
print(self.client_count)
|
|
return s
|
|
|
|
|
|
class IoTMultiClientConfig(MultiInterfaceConfig):
|
|
NAME = "IoTMultiClient"
|
|
|
|
def __init__(self, topo, param):
|
|
super(IoTMultiClientConfig, self).__init__(topo, param)
|
|
|
|
def configure_routing(self):
|
|
super(IoTMultiClientConfig, self).configure_routing()
|
|
for ci in range(len(self.clients)):
|
|
for i, _ in enumerate(self.topo.c2r_links):
|
|
# Routing for the congestion client
|
|
cmd = self.add_global_default_route_command(self.get_router_ip_to_client_switch(i),
|
|
self.get_client_interface(ci, i))
|
|
self.topo.command_to(self.clients[ci], cmd)
|
|
|
|
for i, s in enumerate(self.topo.servers):
|
|
# Routing for the congestion server
|
|
cmd = self.add_simple_default_route_command(
|
|
self.get_router_ip_to_server_switch(i))
|
|
self.topo.command_to(s, cmd)
|
|
|
|
def configure_interfaces(self):
|
|
logging.info(
|
|
"Configure interfaces using IoTMultiClientConfig...")
|
|
super(IoTMultiClientConfig, self).configure_interfaces()
|
|
self.clients = [self.topo.get_client(
|
|
i) for i in range(0, self.topo.client_count())]
|
|
self.servers = [self.topo.get_server(
|
|
i) for i in range(0, self.topo.server_count())]
|
|
netmask = "255.255.255.0"
|
|
for ci in range(len(self.clients)):
|
|
self.configure_client(ci)
|
|
# for i, _ in enumerate(self.topo.c2r_links):
|
|
# # Congestion client
|
|
# cmd = self.interface_up_command(self.get_client_interface(
|
|
# ci, i), self.get_client_ip(i, ci), netmask)
|
|
# self.topo.command_to(self.clients[ci], cmd)
|
|
# client_interface_mac = self.clients[ci].intf(
|
|
# self.get_client_interface(ci, i)).MAC()
|
|
# self.topo.command_to(self.router, "arp -s {} {}".format(
|
|
# self.get_client_ip(i, ci), client_interface_mac))
|
|
|
|
# router_interface_mac = self.router.intf(
|
|
# self.get_router_interface_to_client_switch(i)).MAC()
|
|
# # Congestion client
|
|
# self.topo.command_to(self.clients[ci], "arp -s {} {}".format(
|
|
# self.get_router_ip_to_client_switch(i), router_interface_mac))
|
|
|
|
for i, s in enumerate(self.servers):
|
|
cmd = self.interface_up_command(self.get_router_interface_to_server_switch(i),
|
|
self.get_router_ip_to_server_switch(i), netmask)
|
|
self.topo.command_to(self.router, cmd)
|
|
router_interface_mac = self.router.intf(
|
|
self.get_router_interface_to_server_switch(i)).MAC()
|
|
self.topo.command_to(s, "arp -s {} {}".format(
|
|
self.get_router_ip_to_server_switch(i), router_interface_mac))
|
|
cmd = self.interface_up_command(self.get_server_interface(
|
|
i, 0), self.get_server_ip(interface_index=i), netmask)
|
|
self.topo.command_to(s, cmd)
|
|
server_interface_mac = s.intf(
|
|
self.get_server_interface(i, 0)).MAC()
|
|
self.topo.command_to(self.router, "arp -s {} {}".format(
|
|
self.get_server_ip(interface_index=i), server_interface_mac))
|
|
|
|
def configure_client(self, ci):
|
|
netmask = "255.255.255.0"
|
|
for i, _ in enumerate(self.topo.c2r_links):
|
|
# Congestion client
|
|
cmd = self.interface_up_command(self.get_client_interface(
|
|
ci, i), self.get_client_ip(i, ci), netmask)
|
|
self.topo.command_to(self.clients[ci], cmd)
|
|
client_interface_mac = self.clients[ci].intf(
|
|
self.get_client_interface(ci, i)).MAC()
|
|
self.topo.command_to(self.router, "arp -s {} {}".format(
|
|
self.get_client_ip(i, ci), client_interface_mac))
|
|
|
|
router_interface_mac = self.router.intf(
|
|
self.get_router_interface_to_client_switch(i)).MAC()
|
|
# Congestion client
|
|
self.topo.command_to(self.clients[ci], "arp -s {} {}".format(
|
|
self.get_router_ip_to_client_switch(i), router_interface_mac))
|
|
|
|
def get_client_ip(self, interface_index, client_index=100):
|
|
return "{}{}.{}".format(self.param.get(TopoParameter.LEFT_SUBNET), interface_index, 5+client_index)
|
|
|
|
def server_interface_count(self):
|
|
return max(len(self.servers), 1)
|