前言
在前后端分离开发的项目当中为了避免重复构建发布,我们需要部署一个持续发布环境,而目前的开发环境服务器都是基于 CentOS 的,因此每次在本地发布之后还需要打包,上传,部署,十分繁琐。故这里采用了比较成熟的Jenkins 作为持续部署环境。
为了方便安装,我们这里使用了 Docker 来进行安装,至于 Docker 安装的步骤这里不在赘述,详情可以参考这一篇博文。
上面安装的是一个较老的版本,这里推荐参考Docker 官方文档来进行安装。
安装好 Docker 之后,拉取 Jenkins 的官方镜像。执行如下命令:
docker pull jenkins/jenkins
拉取完毕之后我们基于这个镜像封装一个新的镜像出来,可能会问为什么不能直接使用呢?因为这儿的 jenkins镜像并不包含 docker 环境,所以我们需要封装一个新的镜像让其能够访问宿主机的 Docker 程序。
构建 Dockerfile 内容如下:
FROM jenkins/jenkins:latest
USER root
#清除了基础镜像设置的源,切换成阿里云的源
RUN echo '' > /etc/apt/sources.list.d/jessie-backports.list
&& echo "deb http://www.easck.com/debian jessie main contrib non-free" > /etc/apt/sources.list
&& echo "deb http://www.easck.com/debian jessie-updates main contrib non-free" >> /etc/apt/sources.list
&& echo "deb http://www.easck.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
完成之后执行如下命令构建新的 Docker 镜像:
docker build -t docker/jenkins .
下面我们就开始运行我们的 Jenkins 容器了:
docker run -d -p 8080:8080 -p 50000:50000
--name=jenkins -v /root/docker/jenkins:/var/jenkins_home
-v /var/run/docker.sock:/var/run/docker.sock
-v $(which docker):/usr/bin/docker
docker/jenkins
这里我们将 Jenkins 镜像里面的 /var/jenkins_home 映射到了宿主机的 /root/docker/jenkins 文件夹,在这个文件夹里面都存放的是 Jenkins 的一些配置项等。
注意,这里可能会出现如下错误:
touch: cannot touch ‘/var/jenkins_home/copy_reference_file.log': Permission denied
Can not write to /var/jenkins_home/copy_reference_file.log. Wrong volume permissions?
这是因为在 docker 内部的 jenkins user 用户没有权限,因为映射的 /root/docker/jenkins/ 文件夹属于root 用户的,而 jenkins user 的 uid 为 1000,执行如下命令:
sudo chown -R 1000:1000 /home/docker/jenkins










