mtcp_mpcs.py 1.7 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import modes.experiments as exp
import modes.simulators as sim
import modes.nodeconfig as node


mpcs = [1, 8, 128]
stacks = ['linux', 'mtcp']
server_cores = 8
client_cores = 4
num_clients = 4
connections = 512
msg_size = 64

experiments = []
for mpc in mpcs:
  for stack in stacks:
    e = exp.Experiment('qemu-ib-switch-mtcp_mpc-%s-%d' % (stack,mpc))
    e.timeout = 5* 60
    # add meta data for output file
    e.metadata['mpc'] = mpc
    e.metadata['stack'] = stack

    net = sim.SwitchNet()
    e.add_network(net)

    if stack == 'tas':
        n = node.TASNode
    elif stack == 'mtcp':
        n = node.MtcpNode
    else:
        n = node.I40eLinuxNode

    servers = sim.create_basic_hosts(e, 1, 'server', net, sim.I40eNIC, sim.QemuHost,
            n, node.RPCServer)

    clients = sim.create_basic_hosts(e, num_clients, 'client', net, sim.I40eNIC,
            sim.QemuHost, n, node.RPCClient, ip_start = 2)

    for h in servers:
        h.node_config.cores = server_cores
        h.node_config.app.threads = server_cores
        h.node_config.app.max_flows = connections * 4
        h.sleep = 5



    for c in clients:
        c.wait = True
        c.node_config.cores = client_cores
        c.node_config.app.threads = client_cores

        c.node_config.app.server_ip = servers[0].node_config.ip
        c.node_config.app.max_msgs_conn = mpc
        c.node_config.app.max_flows = \
            int(connections / num_clients / client_cores)

    for h in servers + clients:
        h.node_config.app.max_bytes = msg_size

        if stack == 'linux':
            h.node_config.disk_image = 'tas'
        elif stack == 'tas':
            c.node_config.cores += 2
            c.node_config.fp_cores = 1
    experiments.append(e)