Add TCP barrier
This commit is contained in:
parent
d52d4fc3a9
commit
4c1447bb5e
56
barrier.py
Executable file
56
barrier.py
Executable file
@ -0,0 +1,56 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
import argparse
|
||||||
|
import socket
|
||||||
|
|
||||||
|
def barrier(host, port, wait_for):
|
||||||
|
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
|
||||||
|
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
|
s.bind((host, port))
|
||||||
|
s.listen()
|
||||||
|
|
||||||
|
connections = []
|
||||||
|
addresses = []
|
||||||
|
|
||||||
|
while True:
|
||||||
|
conn, addr = s.accept()
|
||||||
|
connections.append(conn)
|
||||||
|
addresses.append(addr)
|
||||||
|
print("Connection from {}".format(addr))
|
||||||
|
|
||||||
|
if len(connections) == wait_for:
|
||||||
|
break
|
||||||
|
|
||||||
|
for conn in connections:
|
||||||
|
conn.close()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
"--host",
|
||||||
|
default="0.0.0.0",
|
||||||
|
dest="host",
|
||||||
|
help="IP address where the barrier listens to (default: any)",
|
||||||
|
)
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
"--port",
|
||||||
|
default=11000,
|
||||||
|
type=int,
|
||||||
|
dest="port",
|
||||||
|
help="TCP port where the barrier listens to (default: 11000)",
|
||||||
|
)
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
"--processes",
|
||||||
|
required=True,
|
||||||
|
type=int,
|
||||||
|
dest="processes",
|
||||||
|
help="Number of processes the barrier waits for",
|
||||||
|
)
|
||||||
|
|
||||||
|
results = parser.parse_args()
|
||||||
|
|
||||||
|
print("Barrier listens on {}:{} and waits for {} processes".format(results.host, results.port, results.processes))
|
||||||
|
barrier(results.host, results.port, results.processes)
|
Loading…
x
Reference in New Issue
Block a user