1
0
mirror of https://github.com/checktheroads/hyperglass synced 2024-05-11 05:55:08 +00:00
checktheroads-hyperglass/hyperglass/gunicorn_config.py.example

48 lines
1.3 KiB
Plaintext
Raw Normal View History

"""
https://github.com/checktheroads/hyperglass
Guncorn configuration
"""
import os
import shutil
2019-05-11 23:22:27 -07:00
import multiprocessing
from logzero import logger
2019-05-11 23:22:27 -07:00
command = "/usr/local/bin/gunicorn"
2019-05-28 14:14:42 -07:00
pythonpath = "/opt/hyperglass"
2019-05-11 23:22:27 -07:00
bind = "[::1]:8001"
2019-05-28 14:14:42 -07:00
preload = True
workers = multiprocessing.cpu_count() * 2
2019-05-11 23:22:27 -07:00
user = "www-data"
2019-05-11 23:28:13 -07:00
timeout = 60
2019-05-28 14:14:42 -07:00
keepalive = 10
# Prometheus Multiprocessing directory, set as environment variable
2019-06-11 22:28:30 -07:00
prometheus_multiproc_dir = "/tmp/prometheus_multiproc_dir"
def on_starting(server): # pylint: disable=unused-argument
"""Pre-startup Gunicorn Tasks"""
try:
# Renders Jinja2 -> Sass, compiles Sass -> CSS prior to worker load
import hyperglass.render
hyperglass.render.css()
print(1)
except ImportError as error_exception:
logger.error(f"Exception occurred:\n{error_exception}")
2019-06-11 22:28:30 -07:00
# Prometheus multiprocessing directory
shutil.rmtree(prometheus_multiproc_dir)
os.mkdir(prometheus_multiproc_dir)
os.environ["prometheus_multiproc_dir"] = prometheus_multiproc_dir
def worker_exit(server, worker): # pylint: disable=unused-argument
"""Prometheus multiprocessing WSGI support"""
from prometheus_client import multiprocess
multiprocess.mark_process_dead(worker.pid)
2019-05-28 14:14:42 -07:00
def on_exit(server):
shutil.rmtree(prometheus_multiproc_dir)