зеркало из https://github.com/mozilla/bugbug.git
35 строки
1.1 KiB
Python
35 строки
1.1 KiB
Python
|
#!/usr/bin/env python
|
||
|
# -*- coding: utf-8 -*-
|
||
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
||
|
# License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||
|
# You can obtain one at http://mozilla.org/MPL/2.0/.
|
||
|
|
||
|
import os
|
||
|
import sys
|
||
|
from os.path import abspath, dirname, join
|
||
|
|
||
|
from redis import Redis
|
||
|
from rq import Connection, Worker
|
||
|
|
||
|
sys.path.insert(0, abspath(join(dirname(__file__), "..")))
|
||
|
|
||
|
# We need to make sure that the models.py file is imported with the same name
|
||
|
# than in the HTTP docker container or the cache will not match. If we import
|
||
|
# it as models, the cache will be located at
|
||
|
# `sys.modules['models'].MODEL_CACHE` while the job will look the models in
|
||
|
# `sys.modules['http_service.models'].MODEL_CACHE`
|
||
|
import http_service.models # noqa: E402 isort:skip
|
||
|
|
||
|
# Preload libraries
|
||
|
http_service.models.preload_models()
|
||
|
|
||
|
# Provide queue names to listen to as arguments to this script,
|
||
|
# similar to rq worker
|
||
|
redis_url = os.environ.get("REDIS_URL", "redis://localhost/0")
|
||
|
redis_conn = Redis.from_url(redis_url)
|
||
|
with Connection(connection=redis_conn):
|
||
|
qs = sys.argv[1:] or ["default"]
|
||
|
|
||
|
w = Worker(qs)
|
||
|
w.work()
|