Docker容器內的Jenkins使用容器外宿主機的Docker(即DooD,還有另外的狀況就是DioD),google一下有幾種說法,可是都沒試成功(試過一種就是修改宿主機/etc/default/docker的DOCKER_OPTS配置,老是出現拒絕訪問的問題,其實就是容器的jenkins用戶沒有權限訪問容器外的docker命令),按照大神的思路,把容器內的jenkins用戶加入到docker組中,便可成功訪問docker命令了。linux
鏡像Dockerfile:docker
FROM jenkins USER root ARG dockerGid=999 RUN echo "docker:x:${dockerGid}:jenkins" >> /etc/group USER jenkins
構建和啓動鏡像:shell
$ docker build . -t my-jenkins
$ docker run --name jenkins -p 7080:8080 -p 50000:50000 -v /etc/timezone:/etc/timezone -v /etc/localtime:/etc/localtime -v /var/docker_data/jenkins/jenkins_home:/var/jenkins_home -v /var/docker_data/jenkins/settings:/var/settings -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/usr/bin/docker -d my-jenkins
注意這兩個volume參數(將jenkins容器內的docker命令指向了宿主機):
-v /var/run/docker.sock:/var/run/docker.sock
-v $(which docker):/usr/bin/docker
以後直接在jenkins的project裏面就能夠使用docker命令了,好比使用maven的docker插件打包鏡像。
以後再另一臺機器部署jenkins的時候發現的這個問題,就是再jenkins容器內調用docker命令時報錯(上一次能夠是由於我裝jenkins上裝了一些插件,這些插件已經安裝了這些包):maven
docker: error while loading shared libraries: libltdl.so.7: cannot open shared object file: No such file or directory Build step 'Execute shell' marked build as failure
緣由是jenkins容器內部沒有這個包,解決的辦法有兩個:ui
一、將容器宿主機的包映射到容器內: google
#省略了其餘docker運行參數,只列出了缺乏的包映射volume
$ docker run --name jenkins -v /usr/lib/x86_64-linux-gnu/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7 -d my-jenkins
二、對jenkins鏡像進行封裝,官方的jenkins鏡像是基於debian jessie的,dockerfile最好把源切換成國內的。Dockerfile內容以下:阿里雲
FROM jenkins USER root #清除了基礎鏡像設置的源,切換成阿里雲的jessie源 RUN echo '' > /etc/apt/sources.list.d/jessie-backports.list \ && echo "deb http://mirrors.aliyun.com/debian jessie main contrib non-free" > /etc/apt/sources.list \ && echo "deb http://mirrors.aliyun.com/debian jessie-updates main contrib non-free" >> /etc/apt/sources.list \ && echo "deb http://mirrors.aliyun.com/debian-security jessie/updates main contrib non-free" >> /etc/apt/sources.list #更新源並安裝缺乏的包 RUN apt-get update && apt-get install -y libltdl7 ARG dockerGid=999 RUN echo "docker:x:${dockerGid}:jenkins" >> /etc/group \ USER jenkins