diff options
author | Wojciech Kosior <kwojtus@protonmail.com> | 2020-06-12 16:56:36 +0200 |
---|---|---|
committer | Wojciech Kosior <kwojtus@protonmail.com> | 2020-06-12 16:56:36 +0200 |
commit | eaf411175906eebaf8bb4411c9232b054f7222bd (patch) | |
tree | b58cde30aed48b26c66a3a23acae014b1cabe3b6 | |
parent | afcc73eb215e8f873ed982a869e515e0450f6a56 (diff) | |
download | 0tdns-eaf411175906eebaf8bb4411c9232b054f7222bd.tar.gz 0tdns-eaf411175906eebaf8bb4411c9232b054f7222bd.zip |
create vpn connections in parallel
-rwxr-xr-x | src/hourly.py | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/src/hourly.py b/src/hourly.py index da6cf3b..3aa821d 100755 --- a/src/hourly.py +++ b/src/hourly.py @@ -3,7 +3,7 @@ from sys import argv import subprocess from os import path -from time import gmtime, strftime +from time import gmtime, strftime, sleep # our own module used by several scripts in the project from ztdns_db_connectivity import start_db_connection, \ @@ -18,7 +18,7 @@ def sync_ovpn_config(cursor, vpn_id, config_path, config_hash): from user_side_vpn where id = %s and ovpn_config_sha256 = %s ''', (vpn_id, config_hash)) - + (config_contents,) = cursor.fetchone() print(config_contents.tobytes()) @@ -44,7 +44,7 @@ with open("/var/log/0tdns.log", "w") as logfile: # of the formats accepted by postgres hour = strftime('%Y-%m-%d %H:00', gmtime()) logfile.write("Running for {}\n".format(hour)) - + ztdns_config = get_ztdns_config() if ztdns_config['enabled'] != 'yes': logfile.write("0tdns not enabled in the config - exiting\n") @@ -70,11 +70,20 @@ with open("/var/log/0tdns.log", "w") as logfile: cursor.close() connection.close() + subprocesses = [] + for vpn_id, config_hash in vpns: config_path = "/var/lib/0tdns/{}.ovpn".format(config_hash) physical_ip = get_default_host_address(ztdns_config['host']) route_through_veth = ztdns_config['host'] + "/32" command_in_namespace = [perform_queries, hour, str(vpn_id)] logfile.write("Running connection for vpn {}\n".format(vpn_id)) - subprocess.run([wrapper, config_path, physical_ip, - route_through_veth] + command_in_namespace) + + p = subprocess.Popen([wrapper, config_path, physical_ip, + route_through_veth] + command_in_namespace) + + subprocesses.append(p) + sleep(5) + + for p in subprocesses: + p.wait() |