docker-odoo/16.0/wait-for-psql.py
Josh Santos 5740583e38
Improvements for psql wait script.
* support: Move to shared directory to avoid code drift.
* feat: Make DB name configurable
2024-03-31 18:29:51 -04:00

36 lines
1.0 KiB
Python
Executable File

#!/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)
arg_parser.add_argument('--db_password', required=True)
arg_parser.add_argument('--timeout', type=int, default=5)
args = arg_parser.parse_args()
conn = None
start_time = time.time()
error = ''
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()
break
except psycopg2.OperationalError as e:
error = e
time.sleep(1)
if error:
print("Database connection failure: %s" % error, file=sys.stderr)
sys.exit(1)