Я следую этому учебнику и настраиваю связанный с фоном Celery код для моего проекта.
В моем случае я работаю в среде Docker, и у меня есть защищенный сайт (т. е. https://localhost).
Я изменил код для безопасного соединения следующим образом:
key_file = '/etc/nginx/ssl/localhost.key'
cert_file = '/etc/nginx/ssl/localhost.crt'
ca_file = '/etc/nginx/ssl/localhost.ca.crt'
app.config['CELERY_BROKER_URL'] = 'rediss://redis:6380/0'
app.config['CELERY_RESULT_BACKEND'] = 'rediss://redis:6380/0'
def make_celery(app):
"""Setup celery."""
celery = Celery(app.import_name,
backend=app.config['CELERY_RESULT_BACKEND'],
broker=app.config['CELERY_BROKER_URL'],
broker_use_ssl = {
'ssl_keyfile': key_file,
'ssl_certfile': cert_file,
'ssl_ca_certs': ca_file,
'ssl_cert_reqs': ssl.CERT_REQUIRED
},
redis_backend_use_ssl = {
'ssl_keyfile': key_file,
'ssl_certfile': cert_file,
'ssl_ca_certs': ca_file,
'ssl_cert_reqs': ssl.CERT_REQUIRED
})
Мой docker -компонентный файл выглядит следующим образом:
version: '3'
services:
web:
restart: always
build:
context: ./web
dockerfile: Dockerfile
expose:
- "8000"
volumes:
- /home/avner/avner/constructionOverlay/code/meshlabjs/branches/meshlabjs_avnerV1/webServer/web:/home/flask/app/web
- data2:/home/flask/app/web/project/avner/img
command: /usr/local/bin/gunicorn -w 2 -t 3600 -b :8000 project:app
depends_on:
- postgres
stdin_open: true
tty: true
nginx:
restart: always
build:
context: ./nginx
dockerfile: Dockerfile
ports:
- "80:80"
- "443:443"
volumes:
- /home/avner/avner/constructionOverlay/code/meshlabjs/branches/meshlabjs_avnerV1/webServer/web:/home/flask/app/web
- data2:/home/flask/app/web/project/avner/img
depends_on:
- web
postgres:
restart: always
build:
context: ./postgresql
dockerfile: Dockerfile
volumes:
- data1:/var/lib/postgresql/data
expose:
- "5432"
redis:
container_name: redis
hostname: redis
image: "redis:alpine"
command: --port 6380
restart: always
expose:
- '6380'
ports:
- "6380:6380"
volumes:
- /home/avner/avner/constructionOverlay/code/meshlabjs/branches/meshlabjs_avnerV1/webServer/redis/redis.conf:/usr/local/etc/redis/redis.conf
celery:
build:
context: ./web
command: watchmedo auto-restart --directory=./ --pattern=*.py --recursive -- celery worker -A project.celery --loglevel=info
volumes:
- /home/avner/avner/constructionOverlay/code/meshlabjs/branches/meshlabjs_avnerV1/webServer/web:/home/flask/app/web
- /home/avner/avner/constructionOverlay/code/meshlabjs/branches/meshlabjs_avnerV1/webServer/nginx/ssl:/etc/nginx/ssl
- data2:/home/flask/app/web/project/avner/img
depends_on:
- redis
volumes:
data1:
data2:
Файлы: key_file, cert_file и ca_file создаются с использованием собственного CA со следующими шагами, аналогичными шагам здесь :
- создать собственный CA
- подписать сертификат на мой локальный хост, за исключением Docker
- смонтировать файлы в Docker
После внесения этого изменения я не вижу ошибок подключения. Контейнеры запускаются нормально, и файл журнала вполне!
Но во время выполнения при вызове задачи Celery из моего веб-контейнера в моем веб-контейнере появляется ошибка.
Из моего javascript У меня есть вызов POST:
let queryUrl = 'http://localhost/api/v1_2/create_zip_file3';
let fetchData = {
method: 'POST',
};
let response = await fetch(queryUrl, fetchData);
Вот код в Flask веб-контейнере:
@sites_api_blueprint.route('/api/v1_2/create_zip_file', methods=['POST'])
def create_zip_file():
print( 'BEG create_zip_file' )
task = create_zip_file_task.delay(current_user_id=current_user.id)
return jsonify({}), 202, {'Location': url_for('create_zip_file_taskstatus', task_id=task.id)}
@celery.task(bind=True)
def create_zip_file_task(self, current_user_id):
print( 'BEG create_zip_file_task' )
# do some stuff
# ...
# taskstatus -> create_zip_file_taskstatus
@app.route('/status/<task_id>')
def create_zip_file_taskstatus(task_id):
# return the progress status
# ...
Ошибка в веб-контейнере:
docker logs -f webserver_web_1
...
BEG create_zip_file
172.20.0.5 - - [14/Feb/2020 05:48:32] "POST /api/v1_2/create_zip_file HTTP/1.0" 500 -
Traceback (most recent call last):
File "/usr/local/lib/python3.7/site-packages/redis/connection.py", line 492, in connect
sock = self._connect()
File "/usr/local/lib/python3.7/site-packages/redis/connection.py", line 742, in _connect
keyfile=self.keyfile)
FileNotFoundError: [Errno 2] No such file or directory
Что я делаю не так?
Спасибо, Авнер