【问题标题】:Run docker with jenkins user inside jenkins container on Centos7在 Centos7 上的 jenkins 容器内使用 jenkins 用户运行 docker
【发布时间】:2016-12-10 06:30:14
【问题描述】:

我尝试在 Centos7.1 上的 Jenkins 从属容器中运行 Docker。 这是我在 dockerfile 中执行的步骤:

FROM java:8
ARG user=jenkins
ARG group=jenkins
ARG uid=1000
ARG gid=1000
RUN groupadd -g ${gid} ${group} \
&& useradd -d "$JENKINS_HOME" -u ${uid} -g ${gid} -m -s /bin/bash ${user}
RUN groupadd -g 983 docker \
&& gpasswd -a ${user} docker

所以我有一个用户 jenkins (id1000) 在一个组 jenkins (gid1000) + 在一个组 docker (gid983) 中。我为什么选择gid 983? 好吧,如果我在主机上查看/etc/group,我会看到:

docker:x:983:centos

在我的 docker-compose 脚本中,我安装了我的 docker 套接字,这就是我使用与主机上相同的 gid 的原因。

docker-compose 的一部分:

volumes:
  - /var/run/docker.sock:/var/run/docker.sock
  - /usr/bin/docker:/usr/bin/docker

当我以 root 身份在容器内exec 时:

root@c4af16c386d7:/var/jenkins_home# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
jenkins-slave       1.0                 94a5d6606f86        10 minutes 
jenkins             2.7.1               b4974ba62598        3 weeks ago         741 MB
java                8-jdk               264282a59a95        7 weeks ago         669.2 MB

但作为詹金斯用户:

Cannot connect to the Docker daemon. Is the docker daemon running on this host?

在我的容器中:

cat /etc/passwd
jenkins:x:1000:1000::/var/jenkins_home:/bin/bash

cat /etc/group
jenkins:x:1000:
docker:x:983:jenkins

加法:

$ docker exec -it ec52d4125a02 bash
root@ec52d4125a02:/var/jenkins_home# whoami
root
root@ec52d4125a02:/var/jenkins_home# su jenkins
jenkins@ec52d4125a02:~$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                                                                      NAMES
a23521523249        jenkins:2.7.1       "/bin/tini -- /usr/lo"   20 minutes ago      Up 20 minutes       0.0.0.0:8080->8080/tcp, 0.0.0.0:32777->22/tcp, 0.0.0.0:32776->50000/tcp    jenkins-master
ec52d4125a02        jenkins-slave:1.0   "setup-sshd"             20 minutes ago      Up 20 minutes       0.0.0.0:32775->22/tcp, 0.0.0.0:32774->8080/tcp, 0.0.0.0:32773->50000/tcp   jenkins-slave

但是:

$ docker exec -it -u jenkins ec52d4125a02 bash
jenkins@ec52d4125a02:~$ docker ps
Cannot connect to the Docker daemon. Is the docker daemon running on this host?

在第一种情况下,我的詹金斯用户:

uid=1000(jenkins) gid=1000(jenkins) groups=1000(jenkins),983(docker)

第二种情况:

uid=1000(jenkins) gid=1000(jenkins) groups=1000(jenkins)

【问题讨论】:

  • 您缺少能够重新创建问题所需的几个关键部分。特别是 Dockerfile 中的 FROM 行。我做了类似的事情,主要区别在于我的 Jenkins 映像安装 Docker 而不是挂载可执行文件,并且我的命令是基于 debian 的。您的 $DOCKER_HOST 变量是否在您的容器中定义?
  • 变量未定义。实际上,我尝试在使用 docker compose 创建的 jenkins-slave 中将 docker 用作 jenkinsuser。它只是一个带有 java 和 SSH 访问的容器,它有一个 jenkins-user + 组和挂载的 docker 卷。它在 dockerfile 中并不真正包含 jenkins(它来自 master)。我已经添加了我的 FROM + 我不使用那个变量。
  • @BMitch 我还在我的问题中添加了一个补充内容。
  • 我在我的实验室里运行了你的 Dockerfile。使用 jenkins 用户运行在 id 的输出中显示 gid 983。无法重现您的问题。

标签: jenkins docker dockerfile


【解决方案1】:

首先,为什么需要使用 Jenkins 从另一个容器中旋转容器?这是why 这不是一个好主意。

话虽如此,您仍然想继续。首先,在 Docker 容器中运行 Docker 需要执行几个步骤。比如你是否以--priviledged模式启动了这个容器?

您应该尝试使用 Jerome Petazzoni 的 Docker in Docker,就像使用 everything you need 一样。

然后,您可以将 DInD 的东西与 Jenkins 安装结合起来。这是我通过将 Jerome 的 DInD 与其他东西混合并组装一个包含 Jenkins、Docker Compose 和其他有用东西的 docker 容器而组合在一起的示例:

Dockerfile:

FROM ubuntu:xenial
ENV UBUNTU_FLAVOR xenial

#== Ubuntu flavors - common
RUN  echo "deb http://archive.ubuntu.com/ubuntu ${UBUNTU_FLAVOR} main universe\n" > /etc/apt/sources.list \
  && echo "deb http://archive.ubuntu.com/ubuntu ${UBUNTU_FLAVOR}-updates main universe\n" >> /etc/apt/sources.list

MAINTAINER Rogério Peixoto

ENV JENKINS_HOME /var/jenkins_home
ENV JENKINS_SLAVE_AGENT_PORT 50000

ARG user=jenkins
ARG group=jenkins
ARG uid=1000
ARG gid=1000

# Jenkins is run with user `jenkins`, uid = 1000
# If you bind mount a volume from the host or a data container,
# ensure you use the same uid
RUN groupadd -g ${gid} ${group} \
&& useradd -d "$JENKINS_HOME" -u ${uid} -g ${gid} -m -s /bin/bash ${user}

 # useful stuff.
 RUN apt-get update -q && apt-get install -qy \
    apt-transport-https \
    ca-certificates \
    curl \
    lxc \
    supervisor \
    zip \
    git \
    iptables \
    locales \
    nano \
    make \
    openssh-client \
    openjdk-8-jdk-headless \
  && rm -rf /var/lib/apt/lists/*

# Install Docker from Docker Inc. repositories.
RUN curl -sSL https://get.docker.com/ | sh

# Install the wrapper script from https://raw.githubusercontent.com/docker/docker/master/hack/dind.
ADD ./wrapdocker /usr/local/bin/wrapdocker
RUN chmod +x /usr/local/bin/wrapdocker

# Define additional metadata for our image.
VOLUME /var/lib/docker

ENV JENKINS_VERSION 2.8
ENV JENKINS_SHA 4d83a40319ecf4eaab2344a18c197bd693080530

RUN mkdir -p /usr/share/jenkins/ \
  && curl -SL http://repo.jenkins-ci.org/public/org/jenkins-ci/main/jenkins-war/${JENKINS_VERSION}/jenkins-war-${JENKINS_VERSION}.war -o /usr/share/jenkins/jenkins.war
# RUN echo "$JENKINS_SHA  /usr/share/jenkins/jenkins.war" | sha1sum -c -

ENV JENKINS_UC https://updates.jenkins.io
RUN mkdir -p /usr/share/jenkins/ref \
  && chown -R ${user} "$JENKINS_HOME" /usr/share/jenkins/ref

RUN usermod -a -G docker jenkins
ENV DOCKER_COMPOSE_VERSION 1.8.0-rc1

# Install Docker Compose
RUN curl -L https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
RUN chmod +x /usr/local/bin/docker-compose

RUN apt-get install -y python-pip && pip install supervisor-stdout

EXPOSE 8080
EXPOSE 50000

ADD supervisord.conf /etc/supervisor/conf.d/supervisord.conf
CMD ["/usr/bin/supervisord"]

supervisord.conf

[supervisord]
nodaemon=true

[program:docker]
priority=10
command=wrapdocker
startsecs=0
exitcodes=0,1

[program:chown]
priority=20
command=chown -R jenkins:jenkins /var/jenkins_home
startsecs=0

[program:jenkins]
priority=30
user=jenkins
environment=JENKINS_HOME="/var/jenkins_home",HOME="/var/jenkins_home",USER="jenkins"
command=java -jar /usr/share/jenkins/jenkins.war
stdout_events_enabled = true
stderr_events_enabled = true

[eventlistener:stdout]
command=supervisor_stdout
buffer_size=100
events=PROCESS_LOG
result_handler=supervisor_stdout:event_handler

你可以得到wrapdocker file here

将所有内容放在同一个目录中并构建它:

docker build -t my_dind_jenkins .

然后运行它:

docker run -d --privileged \ 
    --name=master-jenkins \
    -p 8080:8080 \
    -p 50000:50000 my_dind_jenkins

【讨论】:

  • 不清楚 OP 是否在执行 DinD,从 docker.sock 的挂载来看,我怀疑他们正在关注您链接的“为什么不应该执行 DinD”文章的解决方案部分。跨度>
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-03-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-12-20
相关资源
最近更新 更多