docker-odoo/17.0/wait-for-psql.py

36 lines
1.0 KiB
Python
Raw Normal View History

2023-11-13 05:50:34 -05:00
#!/usr/bin/env python3
import argparse
import psycopg2
import sys
import time
if __name__ == '__main__':
arg_parser = argparse.ArgumentParser()
arg_parser.add_argument('--db_host', required=True)
arg_parser.add_argument('--db_port', required=True)
arg_parser.add_argument('--db_user', required=True)
arg_parser.add_argument('--db_name', required=True)
2023-11-13 05:50:34 -05:00
arg_parser.add_argument('--db_password', required=True)
arg_parser.add_argument('--timeout', type=int, default=5)
args = arg_parser.parse_args()
conn = None
2023-11-13 05:50:34 -05:00
start_time = time.time()
error = ''
2023-11-13 05:50:34 -05:00
while (time.time() - start_time) < args.timeout:
try:
conn = psycopg2.connect(user=args.db_user, host=args.db_host, port=args.db_port, password=args.db_password, dbname=args.db_name)
conn.close()
2023-11-13 05:50:34 -05:00
break
except psycopg2.OperationalError as e:
error = e
2023-11-13 05:50:34 -05:00
time.sleep(1)
if error:
print("Database connection failure: %s" % error, file=sys.stderr)
sys.exit(1)