当前位置: 首页 > 面试题库 >

如何在以容器运行的Jenkins中运行Docker

宇文鸿畴
2023-03-14
问题内容

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

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


问题答案:

通常,容器中容器的设置涉及链接/var/run/docker.sock及其docker本身。
例如,在此线程中:

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脚本中所示

#!/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(如我在“
在Docker容器中安装后Jenkins不会自动运行 ”中所述)

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

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



 类似资料:
  • 如果我的问题不清楚,请让我知道。PG

  • 只有当docker容器尚未运行时,我才需要运行它。给了这个命令。如果它不存在,我将如何运行它。 我对任何脚本或语言都持开放态度。

  • 我在用“docker外面的docker”和jenkins运行一个容器。我的docker是: 所以所有从“jenkins容器”启动的容器都在主机中运行。 但是,当我试图在需要卷的作业中运行“jenkins容器”中的docker compose时,它采用的是来自主机的路径,而不是jenkins的路径。我是说,当我和docker合作时 它安装在主机的/var/jenkins_home/workspace

  • 我不能和docker一起经营jenkins的形象。它在运行时卡住: afik@ubuntu:~$docker run——名称myjenkins-p8080:8080-p50000:50000-v/var/jenkins_home jenkins

  • 问题内容: 我仅在尚未运行的情况下才需要运行docker容器。给定此命令。如果它不存在,我将如何运行它。 我可以使用任何脚本或语言。 问题答案: 使用过滤器检查是否存在特定名称的容器:( 请参阅docker ps Filterring ) 该如果第一部分是假的,才执行。 为了安全起见(可能会返回多个名称),您也可以选择这样做(如果您认为“ nginx”一词不能作为任何容器名称的一部分): 要么:

  • 假设我们希望在一个不是的环境中开发,因为X-Frame-Options和其他浏览器保护,但不希望每次都进行完全部署。 具体来说,在Windows上,Vue JS和Traefik代理。 理想情况下无需创建新图像。