如何利用Jenkins + TFS为.Net Core实现持续集成/部署详解

2019-12-30 19:41:12王旭

前言

在前后端分离开发的项目当中为了避免重复构建发布,我们需要部署一个持续发布环境,而目前的开发环境服务器都是基于 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