简体   繁体   English

Apache Oozie 可以运行 docker 容器吗?

[英]Can Apache Oozie run docker containers?

Currently comparing DAG-based workflow tools like Airflow and Luigi for scheduling generic docker containers as well as Spark jobs.目前正在比较基于 DAG 的工作流工具,如 Airflow 和 Luigi,用于调度通用 docker 容器以及 Spark 作业。

Can Apache Oozie run generic Docker containers through its shell action? Apache Oozie 能否通过其shell操作运行通用 Docker 容器? Or is Oozie strictly meant for Hadoop tools like Pig and Hive?还是 Oozie 严格适用于 Pig 和 Hive 等 Hadoop 工具?

Oozie is integrated with the rest of the Hadoop stack supporting several types of Hadoop jobs out of the box (such as Java map-reduce, Streaming map-reduce, Pig, Hive, Sqoop and Distcp) as well as system specific jobs (such as Java programs and shell scripts). Oozie 与 Hadoop 堆栈的其余部分集成,支持多种开箱即用的 Hadoop 作业类型(例如 Java map-reduce、Streaming map-reduce、Pig、Hive、Sqoop 和 Distcp)以及系统特定作业(例如Java 程序和 shell 脚本)。

I've tried to run Docker containers through Shell action and it's working.我尝试通过 Shell 操作运行 Docker 容器并且它正在运行。 Since Shell action can be executed on any node of the cluster, Docker must be installed on any node.由于 Shell 动作可以在集群的任何节点上执行,所以 Docker 必须安装在任何节点上。

workflow.xml created from Hue从 Hue 创建的工作流.xml

<workflow-app name="Test docker" xmlns="uri:oozie:workflow:0.5">
    <start to="shell-5c29"/>
    <kill name="Kill">
        <message>Action failed, error message[${wf:errorMessage(wf:lastErrorNode())}]</message>
    </kill>
    <action name="shell-5c29">
        <shell xmlns="uri:oozie:shell-action:0.1">
            <job-tracker>${jobTracker}</job-tracker>
            <name-node>${nameNode}</name-node>
            <exec>test_docker.sh</exec>
            <file>/test_docker.sh#test_docker.sh</file>
        </shell>
        <ok to="End"/>
        <error to="Kill"/>
    </action>
    <end name="End"/>
</workflow-app>

test_docker.sh test_docker.sh

docker run hello-world > output.txt
hdfs dfs -put -f output.txt /output.txt
echo 'done'

Content of output.txt generated生成的 output.txt 的内容

Hello from Docker!
This message shows that your installation appears to be working correctly.

To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub (amd64)
 3. The Docker daemon created a new container from that image which runs the executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/

For more examples and ideas, visit:
 https://docs.docker.com/get-started/

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM