mirror of
https://github.com/titanscouting/tra-superscript.git
synced 2025-01-17 19:15:55 +00:00
solution using zmq PUB/SUB,
working locally
This commit is contained in:
parent
7b05707e3b
commit
c0c46a1b9d
@ -1,19 +1,15 @@
|
|||||||
import socket
|
import signal
|
||||||
|
import zmq
|
||||||
|
|
||||||
client = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, socket.IPPROTO_UDP) # UDP
|
|
||||||
|
|
||||||
# Enable port reusage so we will be able to run multiple clients and servers on single (host, port).
|
signal.signal(signal.SIGINT, signal.SIG_DFL)
|
||||||
# Do not use socket.SO_REUSEADDR except you using linux(kernel<3.9): goto https://stackoverflow.com/questions/14388706/how-do-so-reuseaddr-and-so-reuseport-differ for more information.
|
|
||||||
# For linux hosts all sockets that want to share the same address and port combination must belong to processes that share the same effective user ID!
|
|
||||||
# So, on linux(kernel>=3.9) you have to run multiple servers and clients under one user to share the same (host, port).
|
|
||||||
# Thanks to @stevenreddie
|
|
||||||
client.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT, 1)
|
|
||||||
|
|
||||||
# Enable broadcasting mode
|
context = zmq.Context()
|
||||||
client.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)
|
|
||||||
|
socket = context.socket(zmq.SUB)
|
||||||
|
socket.connect('tcp://localhost:5678')
|
||||||
|
socket.setsockopt(zmq.SUBSCRIBE, b'status')
|
||||||
|
|
||||||
client.bind(("", 5678))
|
|
||||||
while True:
|
while True:
|
||||||
# Thanks @seym45 for a fix
|
message = socket.recv_multipart()
|
||||||
data, addr = client.recvfrom(1024)
|
print(f'Received: {message}')
|
||||||
print("received message: %s"%data)
|
|
@ -156,7 +156,6 @@ import math
|
|||||||
from multiprocessing import Pool, freeze_support
|
from multiprocessing import Pool, freeze_support
|
||||||
import os
|
import os
|
||||||
import pymongo
|
import pymongo
|
||||||
import socket
|
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
import traceback
|
import traceback
|
||||||
@ -314,6 +313,8 @@ def main(send, verbose = False, profile = False, debug = False):
|
|||||||
send(stdout, INF, "closed threads and database client")
|
send(stdout, INF, "closed threads and database client")
|
||||||
send(stdout, INF, "finished all tasks in " + str(time.time() - loop_start) + " seconds, looping")
|
send(stdout, INF, "finished all tasks in " + str(time.time() - loop_start) + " seconds, looping")
|
||||||
|
|
||||||
|
raise Exception("boop")
|
||||||
|
|
||||||
if profile:
|
if profile:
|
||||||
return 0 # return instead of break to avoid sys.exit
|
return 0 # return instead of break to avoid sys.exit
|
||||||
|
|
||||||
@ -547,16 +548,19 @@ def start(pid_path, verbose = False, profile = False, debug = False):
|
|||||||
stderr = f
|
stderr = f
|
||||||
):
|
):
|
||||||
|
|
||||||
server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, socket.IPPROTO_UDP)
|
import zmq
|
||||||
server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEPORT, 1)
|
|
||||||
server.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)
|
context = zmq.Context()
|
||||||
server.settimeout(0.2)
|
socket = context.socket(zmq.PUB)
|
||||||
|
socket.bind("tcp://*:5678")
|
||||||
|
|
||||||
|
socket.send(b'status')
|
||||||
|
|
||||||
def send(target, level, message, code = 0):
|
def send(target, level, message, code = 0):
|
||||||
server.sendto(bytes(message, 'utf-8'), ('<broadcast>', 5678))
|
socket.send(bytes("status: " + message, 'utf-8'))
|
||||||
|
|
||||||
exit_code = main(send)
|
exit_code = main(send)
|
||||||
server.close()
|
socket.close()
|
||||||
f.close()
|
f.close()
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user