如何在作为容器运行的Jenkins中运行Docker

时间:2016-01-11 08:32:25

标签: jenkins docker

我正在使用Centos7。我有一个运行Jenkins的Docker容器。在Jenkins容器中,我必须构建并运行其他Docker容器。但詹金斯并不了解码头工人。我能够执行shell并在容器内安装docker。但是,是否有可能让容器在主机上使用我的docker-engine?我该如何使用它?

在Jenkins-(docker)-container中安装Docker的最佳选择是什么?

2 个答案:

答案 0 :(得分:1)

通常,容器中容器设置涉及链接CardDeck(const Card&); friend bool operator<=(const CardDeck&, const CardDeck&); CardDeck::CardDeck(const Card& card){ _Deck.push_back(card); } /var/run/docker.sock本身 例如,in this thread

docker

这不完全是你的情况,因为你不需要在一个&#34; cic&#34;中运行Jenkins。 (容器中的容器&#34;) 但这说明了如何在容器中运行任何容器,其中包含docker。

确保该容器中的用户是docker组的一部分(如果您不想使用root),如此jenkins/setup-docker-and-start-jenkins.sh script

docker run --name jenkins --privileged=true -t -i --rm -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/bin/docker -p 8080:8080 jenkins

请注意,此设置使用tini启动Jenkins(正如我在&#34中描述的那样; Jenkins does not run automatically after install in Docker container&#34;)

#!/bin/sh
set -e

JUSER="jenkins"

DOCKER_GID=$(ls -aln /var/run/docker.sock  | awk '{print $4}')

if ! getent group $DOCKER_GID; then
    echo creating docker group $DOCKER_GID
    addgroup --gid $DOCKER_GID docker
fi

if ! getent group $GID; then
    echo creating $JUSER group $GID
    addgroup --gid $GID $JUSER
fi

if ! getent passwd $JUSER; then
    echo useradd -N --gid $GID -u $UID $JUSER
    useradd -N --gid $GID -u $UID $JUSER
fi

DOCKER_GROUP=$(ls -al /var/run/docker.sock  | awk '{print $4}')
if ! id -nG "$JUSER" | grep -qw "$DOCKER_GROUP"; then
    adduser $JUSER $DOCKER_GROUP
fi

chown -R $JUSER:$JUSER /var/jenkins_home/

同样,这些脚本是用于&#34; cic&#34; 在您的情况下,您可以将这些脚本用于Jenkins必须运行的容器。

答案 1 :(得分:1)

使用詹金斯官方码头图片:

docker run -d \
    -u root \
    -v /var/run/docker.sock:/var/run/docker.sock \
    -v $(which docker):/usr/bin/docker:ro \
    -p 8080:8080 \
    --name jenkins \
    jenkins

然后验证一切正常:

  • 创建新工作
  • 使用docker version作为内容
  • 添加shell脚本作为构建步骤

如果您在CentOS 7上遇到以下错误:

  

docker:加载共享库时出错:libsystemd-journal.so.0:无法打开共享对象文件:没有这样的文件或目录

然后用:

启动容器
docker run -d \
    -u root \
    -v /var/run/docker.sock:/var/run/docker.sock \
    -v $(which docker):/usr/bin/docker:ro \
    -v /usr/lib64/libsystemd-journal.so.0:/usr/lib/x86_64-linux-gnu/libsystemd-journal.so.0 \
    -v /usr/lib64/libsystemd-id128.so.0:/usr/lib/x86_64-linux-gnu/libsystemd-id128.so.0 \
    -v /usr/lib64/libdevmapper.so.1.02:/usr/lib/x86_64-linux-gnu/libdevmapper.so.1.02 \
    -v /usr/lib64/libgcrypt.so.11:/usr/lib/x86_64-linux-gnu/libgcrypt.so.11 \
    -v /usr/lib64/libdw.so.1:/usr/lib/x86_64-linux-gnu/libdw.so.1 \
    -p 8080:8080 \
    --name jenkins \
    jenkins