Script de déploiement de odoo dans un docker
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

wait-for-psql.py 991B

1234567891011121314151617181920212223242526272829303132
  1. #!/usr/bin/env python3
  2. import argparse
  3. import psycopg2
  4. import sys
  5. import time
  6. if __name__ == '__main__':
  7. arg_parser = argparse.ArgumentParser()
  8. arg_parser.add_argument('--db_host', required=True)
  9. arg_parser.add_argument('--db_port', required=True)
  10. arg_parser.add_argument('--db_user', required=True)
  11. arg_parser.add_argument('--db_password', required=True)
  12. arg_parser.add_argument('--timeout', type=int, default=5)
  13. args = arg_parser.parse_args()
  14. start_time = time.time()
  15. while (time.time() - start_time) < args.timeout:
  16. try:
  17. conn = psycopg2.connect(user=args.db_user, host=args.db_host, port=args.db_port, password=args.db_password, dbname='postgres')
  18. error = ''
  19. break
  20. except psycopg2.OperationalError as e:
  21. error = e
  22. else:
  23. conn.close()
  24. time.sleep(1)
  25. if error:
  26. print("Database connection failure: %s" % error, file=sys.stderr)
  27. sys.exit(1)