使用Docker-in-Jenkins设置Jenkins-in-Docker的最佳实践

时间:2018-03-24 16:59:31

标签: docker jenkins dockerfile jenkins-pipeline

我正在开发一个我希望使用Jenkins持续集成的应用程序,而且我希望能够控制CI的环境。我在OS X本地开发,我正在推动远程Ubuntu 16.04 VM。 这一切都让我想起了Docker。基本上我想要的是Jenkins-in-Docker,还有Docker-in-Jenkins。我的构建从站最初将仅限于 master

现在,我在过去几天一直在阅读有关Docker的一些帖子,但我仍然不能完全确定我是否深入了解它。因此这个问题。

目前,这是我的设置:

詹金斯:

/docker-compose.yml

version: '3'
services:
  jenkins:
    build: ./jenkins
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock # allowing docker-in-docker
      - ./jenkins_home:/var/jenkins_home
    ports:
      - 8080:8080

/jenkins/Dockerfile

FROM docker:17.12 AS docker
FROM jenkins/jenkins:lts

COPY --from=docker /usr/local/bin/docker /usr/local/bin/docker

上面的设置工作正常 - 直到我使用Docker-in-Jenkins。 Jenkins已安装完毕,但是当我构建任何使用 Docker的作业时,我收到错误

  

尝试连接到Docker守护程序时获得权限被拒绝   在unix上的socket:///var/run/docker.sock:发布(...)拨打unix   /var/run/docker.sock:connect:permission denied

CI来源:

/Jenkinsfile

pipeline {
  agent { dockerfile true }
  stages {
    stage('Initial') {
      steps {
        println 'Hello world!'
      }
    }
  }
}

/ Dockerfile

FROM python:3.6-slim-jessie
COPY requirements.txt ./
RUN pip install -r requirements.txt --no-cache-dir
CMD ["python"]

现在回答问题!

首先,显然我错过了容器使用我的主机Docker守护程序的一些权限。我看到this post(以及其他)对此有一些答案。

其次,这甚至是设定方式的预期方式吗?我想以正确的方式学习码头工具,而且我不知道我是否遗漏了一些关于例如多阶段构建?

2 个答案:

答案 0 :(得分:1)

请与docker检查此Dockerfile是否有jenkins。

FROM jenkins/jenkins:lts
MAINTAINER "artem@aleksashkin.com" Artem Aleksashkin

USER root
RUN apt-get update && \
    apt-get -y install apt-transport-https \
         ca-certificates \
         curl \
         gnupg2 \
         software-properties-common && \
    curl -fsSL https://download.docker.com/linux/$(. /etc/os-release; echo "$ID")/gpg > /tmp/dkey; apt-key add /tmp/dkey && \
    add-apt-repository \
       "deb [arch=amd64] https://download.docker.com/linux/$(. /etc/os-release; echo "$ID") \
       $(lsb_release -cs) \
       stable" && \
    apt-get update && \
    apt-get -y install docker-ce && \
    rm -rf /var/lib/apt/lists/* && \
    curl -L "https://github.com/docker/compose/releases/download/1.22.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose && \
    chmod +x /usr/local/bin/docker-compose && \
    usermod -aG docker jenkins

USER jenkins

答案 1 :(得分:0)

使用此Dockerfile:

FROM jenkins/jenkins

USER root

RUN apt-get update RUN apt-get -y install \
    apt-transport-https \
    ca-certificates \
    curl \
    gnupg2 \
    software-properties-common RUN curl -fsSL https://download.docker.com/linux/$(. /etc/os-release; echo "$ID")/gpg | apt-key add - RUN add-apt-repository \    "deb [arch=amd64] https://download.docker.com/linux/$(. /etc/os-release; echo "$ID") \   $(lsb_release -cs) \    stable" RUN apt-get update RUN apt-get -y install docker-ce

USER jenkins