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

发布于 2021-01-31 22:32:47

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

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

关注者
0
被浏览
113
1 个回答
  • 面试哥
    面试哥 2021-01-31
    为面试而生,有面试问题,就找面试哥。

    通常,容器中容器的设置涉及链接/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必须运行的容器。



推荐阅读
知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看