1
0
mirror of https://github.com/quay/quay.git synced 2026-01-27 18:42:52 +03:00
Files
quay/workers/repomirrorworker/repomirrorworker.py
Kenny Lee Sin Cheong 5f63b3a7bb chore: drop deprecated tables and remove unused code (PROJQUAY-522) (#2089)
* chore: drop deprecated tables and remove unused code

* isort imports

* migration: check for table existence before drop
2023-08-25 12:17:24 -04:00

83 lines
2.5 KiB
Python

import argparse
import logging.config
import os
import time
import features
from app import app, repo_mirror_api
from util.log import logfile_path
from util.repomirror.skopeomirror import SkopeoMirror
from util.repomirror.validator import RepoMirrorConfigValidator
from workers.gunicorn_worker import GunicornWorker
from workers.repomirrorworker import process_mirrors
from workers.worker import Worker
logger = logging.getLogger(__name__)
DEFAULT_MIRROR_INTERVAL = 30
class RepoMirrorWorker(Worker):
def __init__(self):
super(RepoMirrorWorker, self).__init__()
RepoMirrorConfigValidator(app.config.get("FEATURE_REPO_MIRROR", False)).valid()
self._mirrorer = SkopeoMirror()
self._next_token = None
interval = app.config.get("REPO_MIRROR_INTERVAL", DEFAULT_MIRROR_INTERVAL)
self.add_operation(self._process_mirrors, interval)
def _process_mirrors(self):
while True:
assert app.config.get("FEATURE_REPO_MIRROR", False)
self._next_token = process_mirrors(self._mirrorer, self._next_token)
if self._next_token is None:
break
def create_gunicorn_worker():
"""
follows the gunicorn application factory pattern, enabling
a quay worker to run as a gunicorn worker thread.
this is useful when utilizing gunicorn's hot reload in local dev.
utilizing this method will enforce a 1:1 quay worker to gunicorn worker ratio.
"""
worker = GunicornWorker(__name__, app, RepoMirrorWorker(), features.REPO_MIRROR)
return worker
if __name__ == "__main__":
pydev_debug = os.getenv("PYDEV_DEBUG", None)
if pydev_debug:
import pydevd_pycharm
host, port = pydev_debug.split(":")
pydevd_pycharm.settrace(
host, port=int(port), stdoutToServer=True, stderrToServer=True, suspend=False
)
logging.config.fileConfig(logfile_path(debug=False), disable_existing_loggers=False)
parser = argparse.ArgumentParser()
parser.add_argument(
"mode", metavar="MODE", type=str, nargs="?", default="", choices=["mirror", ""]
)
args = parser.parse_args()
if app.config.get("ACCOUNT_RECOVERY_MODE", False):
logger.debug("Quay running in account recovery mode")
while True:
time.sleep(100000)
if not features.REPO_MIRROR:
logger.debug("Repository mirror disabled; skipping RepoMirrorWorker")
while True:
time.sleep(100000)
worker = RepoMirrorWorker()
worker.start()