cn-py-serv/server/main.py

30 lines
977 B
Python
Raw Normal View History

2023-12-29 02:13:10 +03:00
import threading
2023-12-22 02:48:34 +03:00
import socket
import logging
import os
2023-12-22 02:48:34 +03:00
2023-12-29 02:13:10 +03:00
import config
2023-12-22 02:48:34 +03:00
log = logging.getLogger(__name__)
2023-12-22 02:48:34 +03:00
def init_server_socket(server_handler):
2023-12-29 02:13:10 +03:00
try:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as main_server_socket:
main_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
log.debug("Attempt to bind socket to 0.0.0.0:{}".format(config.SETUP["server"]["port"]))
2023-12-29 02:13:10 +03:00
main_server_socket.bind(("0.0.0.0", config.SETUP["server"]["port"]))
log.debug("Make socket is listen")
2023-12-29 02:13:10 +03:00
main_server_socket.listen()
while True:
conn, addr = main_server_socket.accept()
log.info("Accepted connection from %s", addr[0])
2023-12-22 02:48:34 +03:00
thr_serv_conn = threading.Thread(target=server_handler, args=(conn, addr,), daemon=True)
2023-12-29 02:13:10 +03:00
thr_serv_conn.run()
2023-12-22 02:48:34 +03:00
2023-12-29 02:13:10 +03:00
except KeyboardInterrupt:
log.info("Server get keyboard interrupt, bye!")