java - 在 Airflow 中设置 DB2

标签 java docker jdbc db2 airflow

我正在尝试将 DB2 作为驻留在 Docker 容器中的 Airflow 的数据连接进行连接(意识到这不受 native 支持)。我正在 Mac 上开发

我已经添加了连接,如下面的屏幕截图所示,其中 URL 为主机:端口/数据库。

Screenshot of the JDBC DB2 Connection

然后,我将转到数据分析 > 即席查询来尝试测试连接,我得到以下结果。

enter image description here

为了确保驱动可用,我将 jdbc 驱动所在的文件夹挂载到 docker-compose 文件中的/usr/local/airflow/drivers 中。

我还确保在我的requirements.txt中包含以下包,因为当我从jupyter笔记本查询时需要这些包。

  • SAS
  • thrift_sasl
  • jaydebeapi
  • jpype1
  • ibm_db
  • ibm_db_sa

我不知道我错过了什么。

我经历过:

这是我当前的 Dockerfile。如评论中所示,Dockerfile 中未安装 JVM,因此这可能是问题所在。

# VERSION 1.10.1
# AUTHOR: Matthieu "Puckel_" Roisil
# DESCRIPTION: Basic Airflow container
# BUILD: docker build --rm -t puckel/docker-airflow .
# SOURCE: https://github.com/puckel/docker-airflow

FROM python:3.6-slim
LABEL maintainer="Puckel_"

# Never prompts the user for choices on installation/configuration of packages
ENV DEBIAN_FRONTEND noninteractive
ENV TERM linux


# Airflow
ARG AIRFLOW_VERSION=1.10.1
ARG AIRFLOW_HOME=/usr/local/airflow
ARG AIRFLOW_DEPS=""
ARG PYTHON_DEPS=""
ENV AIRFLOW_GPL_UNIDECODE yes

# Define en_US.
ENV LANGUAGE en_US.UTF-8
ENV LANG en_US.UTF-8
ENV LC_ALL en_US.UTF-8
ENV LC_CTYPE en_US.UTF-8
ENV LC_MESSAGES en_US.UTF-8

# Java

RUN apt-get update && apt-get install -y openjdk-7-jre-headless wget \
    && apt-get clean 
ENV JAVA_HOME /usr/lib/jvm/java-7-openjdk-amd64

RUN set -ex \
    && buildDeps=' \
        freetds-dev \
        libkrb5-dev \
        libsasl2-dev \
        libssl-dev \
        libffi-dev \
        libpq-dev \
        git \
    ' \
    && apt-get update -yqq \
    && apt-get upgrade -yqq \
    && apt-get install -yqq --no-install-recommends \
        $buildDeps \
        freetds-bin \
        build-essential \
        default-libmysqlclient-dev \
        apt-utils \
        curl \
        rsync \
        netcat \
        locales \
    && sed -i 's/^# en_US.UTF-8 UTF-8$/en_US.UTF-8 UTF-8/g' /etc/locale.gen \
    && locale-gen \
    && update-locale LANG=en_US.UTF-8 LC_ALL=en_US.UTF-8 \
    && useradd -ms /bin/bash -d ${AIRFLOW_HOME} airflow \
    && pip install -U pip setuptools wheel \
    && pip install pytz \
    && pip install pyOpenSSL \
    && pip install ndg-httpsclient \
    && pip install pyasn1 \
    && pip install apache-airflow[crypto,celery,postgres,hive,jdbc,mysql,ssh${AIRFLOW_DEPS:+,}${AIRFLOW_DEPS}]==${AIRFLOW_VERSION} \
    && pip install 'redis>=2.10.5,<3' \
    && if [ -n "${PYTHON_DEPS}" ]; then pip install ${PYTHON_DEPS}; fi \
    && apt-get purge --auto-remove -yqq $buildDeps \


  && apt-get autoremove -yqq --purge \
    && apt-get clean \
    && rm -rf \
        /var/lib/apt/lists/* \
        /tmp/* \
        /var/tmp/* \
        /usr/share/man \
        /usr/share/doc \
        /usr/share/doc-base

COPY script/entrypoint.sh /entrypoint.sh
COPY config/airflow.cfg ${AIRFLOW_HOME}/airflow.cfg
COPY requirements.txt ${AIRFLOW_HOME}/requirements.txt

RUN pip install --upgrade pip && pip install -r requirements.txt
RUN chown -R airflow: ${AIRFLOW_HOME}

EXPOSE 8080 5555 8793

USER airflow
WORKDIR ${AIRFLOW_HOME}
ENTRYPOINT ["/entrypoint.sh"]
CMD ["webserver"] # set default arg for entrypoint

最佳答案

jpype1 模块需要一个 JVM,可以在您的 $PATH 上访问 - 尝试安装一个并重试。

关于java - 在 Airflow 中设置 DB2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53510761/

相关文章:

java - 如何从 mysql 表中获取最后 3 个不同的 ID

Docker 连接到主机 mysql 时出错

mysql - Spring Boot DatasourceBean 错误,Macbook,MySQL

eclipse - 在 Eclipse 中哪里修改 JNDI 的 xml?

java - Lucene 的 StopFilter 中使用的默认停用词列表是什么?

JavaFX 8 如何使用零参数执行 lambda 表达式

java - 多个项目可以有相同的上下文根吗?

docker - 从Docker容器中设置主机的主机名

windows - Windows Git-bash运行docker.sock

postgresql - jOOQ 时间戳与本地时区偏移一起存储