[AIRFLOW-654] Add SSL Config Option for CeleryExecutor w/ RabbitMQ

- Add BROKER_USE_SSL config to give option to send AMQP messages over SSL
- Can be set using usual airflow options (e.g. airflow.cfg, env vars, etc.)

Closes #2333 from forsberg/ssl_amqp
This commit is contained in:
Michael Otte 2017-06-01 10:19:30 +02:00 коммит произвёл Bolke de Bruin
Родитель 71d8f132c3
Коммит 868bfe4cab
2 изменённых файлов: 24 добавлений и 0 удалений

Просмотреть файл

@ -15,6 +15,7 @@
from builtins import object from builtins import object
import logging import logging
import subprocess import subprocess
import ssl
import time import time
from celery import Celery from celery import Celery
@ -46,6 +47,18 @@ class CeleryConfig(object):
CELERYD_CONCURRENCY = configuration.getint('celery', 'CELERYD_CONCURRENCY') CELERYD_CONCURRENCY = configuration.getint('celery', 'CELERYD_CONCURRENCY')
CELERY_DEFAULT_QUEUE = DEFAULT_QUEUE CELERY_DEFAULT_QUEUE = DEFAULT_QUEUE
CELERY_DEFAULT_EXCHANGE = DEFAULT_QUEUE CELERY_DEFAULT_EXCHANGE = DEFAULT_QUEUE
if configuration.get('celery', 'CELERY_SSL_ACTIVE'):
try:
BROKER_USE_SSL = {'keyfile': configuration.get('celery', 'CELERY_SSL_KEY'),
'certfile': configuration.get('celery', 'CELERY_SSL_CERT'),
'ca_certs': configuration.get('celery', 'CELERY_SSL_CACERT'),
'cert_reqs': ssl.CERT_REQUIRED}
except ValueError:
raise AirflowException('ValueError: CELERY_SSL_ACTIVE is True, please ensure CELERY_SSL_KEY, '
'CELERY_SSL_CERT and CELERY_SSL_CACERT are set')
except Exception as e:
raise AirflowException('Exception: There was an unknown Celery SSL Error. Please ensure you want to use '
'SSL and/or have all necessary certs and key.')
app = Celery( app = Celery(
configuration.get('celery', 'CELERY_APP_NAME'), configuration.get('celery', 'CELERY_APP_NAME'),

Просмотреть файл

@ -321,6 +321,17 @@ standard port 443, you'll need to configure that too. Be aware that super user p
web_server_port = 443 web_server_port = 443
base_url = http://<hostname or IP>:443 base_url = http://<hostname or IP>:443
Enable CeleryExecutor with SSL. Ensure you properly generate client and server
certs and keys.
.. code-block:: bash
[celery]
CELERY_SSL_ACTIVE = True
CELERY_SSL_KEY = <path to key>
CELERY_SSL_CERT = <path to cert>
CELERY_SSL_CACERT = <path to cacert>
Impersonation Impersonation
------------- -------------