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

标签 jenkins docker

我正在 Centos7 上工作。我有一个运行 Jenkins 的 Docker 容器。在该 Jenkins 容器中,我必须构建并运行其他 Docker 容器。但 Jenkins 不认识docker。我能够执行 shell 并在容器内安装 docker。但是是不是可以让容器在主机上使用我的docker-engine呢?我该如何使用它?

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

最佳答案

通常,容器中容器设置涉及链接 /var/run/docker.sockdocker 本身。
例如,in this thread :

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

这不完全是你的情况,因为你不需要在“cic”(容器中的容器”)中运行 Jenkins 本身。
但这说明了如何在容器中运行任何容器,其中包含可用的 docker。

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

#!/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/

请注意,此设置使用 tini启动 Jenkins(如我在“Jenkins does not run automatically after install in Docker container”中所述)

exec su $JUSER -c "/bin/tini -- /usr/local/bin/jenkins.sh"

同样,这些脚本用于在“cic”中使用 Jenkins。
对于您的情况,您可以将这些脚本用于 Jenkins 必须运行的容器。

关于jenkins - 如何在作为容器运行的 Jenkins 中运行 Docker,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34717035/

相关文章:

git - Jenkins 配置

java - 使用 cobertura 插件跳过*测试*

docker 在父文件夹中找不到文件?

java - Apache httpcomponent 返回 java.net.UnknownHostException : Name or service not known

docker - 运行容器后无法访问 Airflow 的网络服务器

git - Jenkins Pipeline 忽略 git checkout 的 exludeMessage 选项

java - 使用 Jenkins 在构建时修改 web.xml 中的 <display-name>

docker - 有什么方法可以检索最初用于创建Docker容器的命令?

msbuild - UnitTestFramework 引用无法解析

docker - 无法通过 CircleCI 集成和 docker-compose 连接到 docker 守护进程