Use tenacity for resolver retries

This commit is contained in:
Tim Möhlmann
2018-10-07 00:32:05 +03:00
parent d6c386651d
commit c457ccfa60
6 changed files with 27 additions and 46 deletions

View File

@@ -4,23 +4,16 @@ import jinja2
import os
import socket
import glob
import time
from tenacity import retry
convert = lambda src, dst: open(dst, "w").write(jinja2.Template(open(src).read()).render(**os.environ))
@retry(stop=stop_after_attempt(10), wait=wait_random(min=2, max=5))
def resolve():
os.environ["FRONT_ADDRESS"] = socket.gethostbyname(os.environ.get("FRONT_ADDRESS", "front"))
# Actual startup script
i = 0
t = 10
while True:
i += 1
try:
os.environ["FRONT_ADDRESS"] = socket.gethostbyname(os.environ.get("FRONT_ADDRESS", "front"))
except socket.gaierror as err:
if i >= t:
raise
time.sleep(10)
continue
break
resolve()
if "HOST_REDIS" not in os.environ: os.environ["HOST_REDIS"] = "redis"
for rspamd_file in glob.glob("/conf/*"):