2020-06-24 08:36:26 +00:00
|
|
|
from core.topo import Topo, TopoConfig, TopoParameter
|
2020-06-29 14:23:39 +00:00
|
|
|
import logging
|
|
|
|
|
2015-01-07 13:44:44 +00:00
|
|
|
|
2020-06-24 10:28:44 +00:00
|
|
|
class MultiInterfaceTopo(Topo):
|
|
|
|
NAME = "MultiIf"
|
|
|
|
|
2020-06-29 07:51:55 +00:00
|
|
|
def __init__(self, topo_builder, parameterFile):
|
2020-06-29 14:23:39 +00:00
|
|
|
logging.info("Initializing MultiInterfaceTopo...")
|
2020-06-29 07:51:55 +00:00
|
|
|
super(MultiInterfaceTopo, self).__init__(topo_builder, parameterFile)
|
2020-06-29 14:02:17 +00:00
|
|
|
self.client = self.add_client()
|
|
|
|
self.server = self.add_server()
|
|
|
|
self.router = self.add_router()
|
2020-07-08 12:25:24 +00:00
|
|
|
self.c2r_links = []
|
|
|
|
self.r2s_links = []
|
2020-07-03 13:20:20 +00:00
|
|
|
|
|
|
|
# Add client - router links
|
|
|
|
for l in self.get_client_to_router_links():
|
2020-07-08 12:25:24 +00:00
|
|
|
self.c2r_links.append(self.add_bottleneck_link(self.client, self.router, link_characteristics=l))
|
2020-07-03 13:20:20 +00:00
|
|
|
|
|
|
|
# Special case: if there is no specified link between router and server, directly connect them!
|
|
|
|
if len(self.get_router_to_server_links()) > 0:
|
|
|
|
for l in self.get_router_to_server_links():
|
2020-07-08 12:25:24 +00:00
|
|
|
self.r2s_links.append(self.add_bottleneck_link(self.router, self.server, link_characteristics=l))
|
2020-07-03 13:20:20 +00:00
|
|
|
else:
|
2020-07-02 14:33:42 +00:00
|
|
|
self.add_link(self.router, self.server)
|
2020-07-03 13:20:20 +00:00
|
|
|
|
2020-06-29 07:51:55 +00:00
|
|
|
|
2020-07-03 13:20:20 +00:00
|
|
|
def get_client_to_router_links(self):
|
|
|
|
return [l for l in self.topo_parameter.link_characteristics if l.link_type == "c2r"]
|
2020-06-24 10:28:44 +00:00
|
|
|
|
2020-07-03 13:20:20 +00:00
|
|
|
def get_router_to_server_links(self):
|
|
|
|
return [l for l in self.topo_parameter.link_characteristics if l.link_type == "r2s"]
|
|
|
|
|
2020-06-24 10:28:44 +00:00
|
|
|
def __str__(self):
|
2020-07-03 13:20:20 +00:00
|
|
|
s = "Simple multiple interface topology \n"
|
2020-06-24 10:28:44 +00:00
|
|
|
i = 0
|
2020-07-03 13:20:20 +00:00
|
|
|
nc = len(self.get_client_to_router_links())
|
|
|
|
ns = len(self.get_router_to_server_links())
|
|
|
|
m = max(nc, ns)
|
|
|
|
skipped = 0
|
|
|
|
for i in range(0, m):
|
|
|
|
if i == m // 2:
|
|
|
|
if m % 2 == 0:
|
2020-07-03 13:48:03 +00:00
|
|
|
s = s + "c r s\n"
|
|
|
|
s = s + " \-sw---bl---sw-/ \-sw---bl---sw-/\n"
|
2020-06-24 10:28:44 +00:00
|
|
|
else:
|
2020-07-03 13:20:20 +00:00
|
|
|
s = s + "c--sw---bl---sw--r--sw---bl---sw--s\n"
|
2020-06-24 10:28:44 +00:00
|
|
|
else:
|
2020-07-03 13:20:20 +00:00
|
|
|
if i < m // 2:
|
|
|
|
if (nc == m and ns + skipped == m) or (ns == m and nc + skipped == m):
|
|
|
|
s = s + " /-sw---bl---sw-\ /-sw---bl---sw-\ \n"
|
|
|
|
elif nc == m:
|
|
|
|
s = s + " /-sw---bl---sw-\ \n"
|
|
|
|
skipped += 1
|
|
|
|
else:
|
|
|
|
s = s + " /-sw---bl---sw-\ \n"
|
|
|
|
skipped += 1
|
|
|
|
else:
|
|
|
|
if (nc == m and ns + skipped == m) or (ns == m and nc + skipped == m):
|
|
|
|
s = s + " \-sw---bl---sw-/ \-sw---bl---sw-/ \n"
|
|
|
|
elif nc == m:
|
|
|
|
s = s + " \-sw---bl---sw-/ \n"
|
|
|
|
skipped += 1
|
|
|
|
else:
|
|
|
|
s = s + " \-sw---bl---sw-/ \n"
|
|
|
|
skipped += 1
|
|
|
|
|
2020-06-24 10:28:44 +00:00
|
|
|
return s
|
|
|
|
|
2020-07-03 13:20:20 +00:00
|
|
|
|
2020-06-24 10:28:44 +00:00
|
|
|
class MultiInterfaceConfig(TopoConfig):
|
|
|
|
NAME = "MultiIf"
|
|
|
|
|
2020-06-23 11:20:07 +00:00
|
|
|
def __init__(self, topo, param):
|
2020-06-24 10:28:44 +00:00
|
|
|
super(MultiInterfaceConfig, self).__init__(topo, param)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-29 07:51:55 +00:00
|
|
|
def configure_routing(self):
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.c2r_links):
|
2020-06-29 14:23:39 +00:00
|
|
|
cmd = self.add_table_route_command(self.get_client_ip(i), i)
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-29 07:51:55 +00:00
|
|
|
cmd = self.add_link_scope_route_command(
|
2020-06-29 14:23:39 +00:00
|
|
|
self.get_client_subnet(i),
|
2020-06-29 14:02:17 +00:00
|
|
|
self.get_client_interface(0, i), i)
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:33:42 +00:00
|
|
|
cmd = self.add_table_default_route_command(self.get_router_ip_to_client_switch(i),
|
2020-06-23 11:20:07 +00:00
|
|
|
i)
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.r2s_links):
|
2020-07-02 14:33:42 +00:00
|
|
|
cmd = self.add_table_route_command(self.get_server_ip(i), i)
|
|
|
|
self.topo.command_to(self.server, cmd)
|
|
|
|
|
|
|
|
cmd = self.add_link_scope_route_command(
|
|
|
|
self.get_server_subnet(i),
|
|
|
|
self.get_server_interface(0, i), i)
|
|
|
|
self.topo.command_to(self.server, cmd)
|
|
|
|
|
|
|
|
cmd = self.add_table_default_route_command(self.get_router_ip_to_server_switch(i),
|
|
|
|
i)
|
|
|
|
self.topo.command_to(self.server, cmd)
|
|
|
|
|
|
|
|
cmd = self.add_global_default_route_command(self.get_router_ip_to_client_switch(0),
|
2020-06-29 14:02:17 +00:00
|
|
|
self.get_client_interface(0, 0))
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:33:42 +00:00
|
|
|
cmd = self.add_simple_default_route_command(self.get_router_ip_to_server_switch(0))
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.server, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
|
|
|
|
2020-06-29 07:51:55 +00:00
|
|
|
def configure_interfaces(self):
|
2020-06-29 14:23:39 +00:00
|
|
|
logging.info("Configure interfaces using MultiInterfaceConfig...")
|
2020-06-29 14:02:17 +00:00
|
|
|
super(MultiInterfaceConfig, self).configure_interfaces()
|
|
|
|
self.client = self.topo.get_client(0)
|
|
|
|
self.server = self.topo.get_server(0)
|
|
|
|
self.router = self.topo.get_router(0)
|
2020-06-23 11:20:07 +00:00
|
|
|
netmask = "255.255.255.0"
|
2020-06-29 14:02:17 +00:00
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.c2r_links):
|
2020-06-30 09:23:25 +00:00
|
|
|
cmd = self.interface_up_command(self.get_client_interface(0, i), self.get_client_ip(i), netmask)
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-30 09:23:25 +00:00
|
|
|
client_interface_mac = self.client.intf(self.get_client_interface(0, i)).MAC()
|
|
|
|
self.topo.command_to(self.router, "arp -s {} {}".format(self.get_client_ip(i), client_interface_mac))
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-03 14:59:26 +00:00
|
|
|
if self.topo.get_client_to_router_links()[i].backup:
|
2020-06-30 09:23:25 +00:00
|
|
|
cmd = self.interface_backup_command(self.get_client_interface(0, i))
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.client, cmd)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.c2r_links):
|
2020-07-03 13:20:20 +00:00
|
|
|
cmd = self.interface_up_command(self.get_router_interface_to_client_switch(i),
|
2020-07-02 14:33:42 +00:00
|
|
|
self.get_router_ip_to_client_switch(i), netmask)
|
2020-06-25 08:53:56 +00:00
|
|
|
self.topo.command_to(self.router, cmd)
|
2020-07-03 13:20:20 +00:00
|
|
|
router_interface_mac = self.router.intf(self.get_router_interface_to_client_switch(i)).MAC()
|
2020-06-30 09:23:25 +00:00
|
|
|
self.topo.command_to(self.client, "arp -s {} {}".format(
|
2020-07-02 14:33:42 +00:00
|
|
|
self.get_router_ip_to_client_switch(i), router_interface_mac))
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
if len(self.topo.r2s_links) == 0:
|
2020-07-03 13:20:20 +00:00
|
|
|
# Case no server param is specified
|
|
|
|
cmd = self.interface_up_command(self.get_router_interface_to_server_switch(0),
|
|
|
|
self.get_router_ip_to_server_switch(0), netmask)
|
|
|
|
self.topo.command_to(self.router, cmd)
|
|
|
|
router_interface_mac = self.router.intf(self.get_router_interface_to_server_switch(0)).MAC()
|
|
|
|
self.topo.command_to(self.server, "arp -s {} {}".format(
|
|
|
|
self.get_router_ip_to_server_switch(0), router_interface_mac))
|
|
|
|
|
|
|
|
cmd = self.interface_up_command(self.get_server_interface(0, 0), self.get_server_ip(0), netmask)
|
|
|
|
self.topo.command_to(self.server, cmd)
|
|
|
|
server_interface_mac = self.server.intf(self.get_server_interface(0, 0)).MAC()
|
|
|
|
self.topo.command_to(self.router, "arp -s {} {}".format(
|
|
|
|
self.get_server_ip(0), server_interface_mac))
|
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.r2s_links):
|
2020-07-03 13:20:20 +00:00
|
|
|
cmd = self.interface_up_command(self.get_router_interface_to_server_switch(i),
|
2020-07-02 14:33:42 +00:00
|
|
|
self.get_router_ip_to_server_switch(i), netmask)
|
|
|
|
self.topo.command_to(self.router, cmd)
|
2020-07-03 13:20:20 +00:00
|
|
|
router_interface_mac = self.router.intf(self.get_router_interface_to_server_switch(i)).MAC()
|
2020-07-02 14:33:42 +00:00
|
|
|
self.topo.command_to(self.server, "arp -s {} {}".format(
|
|
|
|
self.get_router_ip_to_server_switch(i), router_interface_mac))
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-08 12:25:24 +00:00
|
|
|
for i, _ in enumerate(self.topo.r2s_links):
|
2020-07-02 14:38:45 +00:00
|
|
|
cmd = self.interface_up_command(self.get_server_interface(0, i), self.get_server_ip(i), netmask)
|
2020-07-02 14:33:42 +00:00
|
|
|
self.topo.command_to(self.server, cmd)
|
2020-07-02 14:38:45 +00:00
|
|
|
server_interface_mac = self.server.intf(self.get_server_interface(0, i)).MAC()
|
2020-07-02 14:33:42 +00:00
|
|
|
self.topo.command_to(self.router, "arp -s {} {}".format(
|
|
|
|
self.get_server_ip(i), server_interface_mac))
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-29 14:23:39 +00:00
|
|
|
def get_client_ip(self, interface_index):
|
|
|
|
return "{}{}.1".format(self.param.get(TopoParameter.LEFT_SUBNET), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-29 14:23:39 +00:00
|
|
|
def get_client_subnet(self, interface_index):
|
|
|
|
return "{}{}.0/24".format(self.param.get(TopoParameter.LEFT_SUBNET), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:33:42 +00:00
|
|
|
def get_router_ip_to_client_switch(self, switch_index):
|
2020-06-29 14:23:39 +00:00
|
|
|
return "{}{}.2".format(self.param.get(TopoParameter.LEFT_SUBNET), switch_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:33:42 +00:00
|
|
|
def get_router_ip_to_server_switch(self, switch_index):
|
2020-07-02 14:38:45 +00:00
|
|
|
return "{}{}.2".format(self.param.get(TopoParameter.RIGHT_SUBNET), switch_index)
|
2020-07-02 14:33:42 +00:00
|
|
|
|
2020-07-02 14:41:08 +00:00
|
|
|
def get_server_ip(self, interface_index=0):
|
2020-07-02 14:38:45 +00:00
|
|
|
return "{}{}.1".format(self.param.get(TopoParameter.RIGHT_SUBNET), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:33:42 +00:00
|
|
|
def get_server_subnet(self, interface_index):
|
|
|
|
return "{}{}.0/24".format(self.param.get(TopoParameter.RIGHT_SUBNET), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-26 09:17:00 +00:00
|
|
|
def client_interface_count(self):
|
2020-07-08 12:25:24 +00:00
|
|
|
return max(len(self.topo.c2r_links), 1)
|
2020-07-03 13:20:20 +00:00
|
|
|
|
|
|
|
def server_interface_count(self):
|
2020-07-08 12:25:24 +00:00
|
|
|
return max(len(self.topo.r2s_links), 1)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-03 13:20:20 +00:00
|
|
|
def get_router_interface_to_server_switch(self, switch_index):
|
2020-07-08 12:25:24 +00:00
|
|
|
return self.get_router_interface_to_client_switch(len(self.topo.c2r_links) + switch_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-06-29 14:02:17 +00:00
|
|
|
def get_client_interface(self, client_index, interface_index):
|
|
|
|
return "{}-eth{}".format(self.topo.get_client_name(client_index), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-03 13:20:20 +00:00
|
|
|
def get_router_interface_to_client_switch(self, interface_index):
|
2020-06-29 14:02:17 +00:00
|
|
|
return "{}-eth{}".format(self.topo.get_router_name(0), interface_index)
|
2020-06-23 11:20:07 +00:00
|
|
|
|
2020-07-02 14:38:45 +00:00
|
|
|
def get_server_interface(self, server_index, interface_index):
|
|
|
|
return "{}-eth{}".format(self.topo.get_server_name(server_index), interface_index)
|