在前后端分离开发的项目当中为了避免重复构建发布,我们需要部署一个持续发布环境,而目前的开发环境服务器都是基于 CentOS 的,因此每次在本地发布之后还需要打包,上传,部署,十分繁琐。故这里采用了比较成熟的Jenkins 作为持续部署环境。

为了方便安装,我们这里使用了 Docker 来进行安装,至于 Docker 安装的步骤这里不在赘述,详情可以参考这一篇博文

上面安装的是一个较老的版本,这里推荐参考Docker 官方文档来进行安装。

安装好 Docker 之后,拉取 Jenkins 的官方镜像。执行如下命令:

  1. docker pull jenkins/jenkins

拉取完毕之后我们基于这个镜像封装一个新的镜像出来,可能会问为什么不能直接使用呢?因为这儿的 jenkins镜像并不包含 docker 环境,所以我们需要封装一个新的镜像让其能够访问宿主机的 Docker 程序。

构建 Dockerfile 内容如下:

  1. FROM jenkins/jenkins:latest
  2. USER root
  3. #清除了基础镜像设置的源,切换成阿里云的源
  4. RUN echo '' > /etc/apt/sources.list.d/jessie-backports.list \
  5. && echo "deb http://mirrors.aliyun.com/debian jessie main contrib non-free" > /etc/apt/sources.list \
  6. && echo "deb http://mirrors.aliyun.com/debian jessie-updates main contrib non-free" >> /etc/apt/sources.list \
  7. && echo "deb http://mirrors.aliyun.com/debian-security jessie/updates main contrib non-free" >> /etc/apt/sources.list
  8. #更新源并安装缺少的包
  9. RUN apt-get update && apt-get install -y libltdl7
  10. ARG dockerGid=999
  11. RUN echo "docker:x:${dockerGid}:jenkins" >> /etc/group \
  12. USER jenkins

完成之后执行如下命令构建新的 Docker 镜像:

  1. docker build -t docker/jenkins .

下面我们就开始运行我们的 Jenkins 容器了:

  1. docker run -d -p 8080:8080 -p 50000:50000 \
  2. --name=jenkins -v /root/docker/jenkins:/var/jenkins_home \
  3. -v /var/run/docker.sock:/var/run/docker.sock \
  4. -v $(which docker):/usr/bin/docker \
  5. docker/jenkins

这里我们将 Jenkins 镜像里面的 /var/jenkins_home 映射到了宿主机的 /root/docker/jenkins 文件夹,在这个文件夹里面都存放的是 Jenkins 的一些配置项等。

注意,这里可能会出现如下错误:

  1. touch: cannot touch ‘/var/jenkins_home/copy_reference_file.log’: Permission denied
  2. 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,执行如下命令:

  1. sudo chown -R 1000:1000 /home/docker/jenkins

之后再次运行 Jenkins 的容器,访问 http://服务器IP:8080/ 站点,会提示你输入密钥:



我们来到宿主机执行以下 shell 命令:

  1. docker container logs jenkins

就可以看到密钥其实已经输出在终端了,复制过来,粘贴进去就可以了。之后就是选择你需要安装的插件,选择第一个默认即可,可能这里因为网络原因会安装失败,可以多重试几次,或者直接忽略掉,后面我们会将如何解决。

安装完成之后输入用户名密码,就可以开始使用了,可能你刚才会因为网络等原因造成插件安装失败,这里我们来到

  1. Jenkins>>系统管理>>管理插件>>高级

然后将 升级站点 地址改为 http://mirror.xmission.com/jenkins/updates/current/update-center.json。之后安装之前缺失的插件。

这里我们项目使用的是 TFS 进行源代码管理,所以我们需要安装 TFS 插件,在 Manage Jenkins 的 Manage Plugin 里面我们找到 Team Foundation Server Plug-in 插件,勾选,点击 Download now and install after restart 按钮,勾选 Restart Jenkins when installation is complete and no jobs are running 。

安装完成之后 Jenkins 会重启,等待重启完毕之后,来到 Jenkins>>Manage Jenkins>>Configure System 查看 TFS/Team Services 然后添加你的 TFS Collection。



保存之后我们就可以新建项目了。

首先,我们来到首页,选择 New Item:



然后选择自由风格项目,填上名称.



在 Source Code Management 上选择 TFS,并且填入你的 TFS 服务器地址,项目路径,与你的账号密码:



然后你就可以尝试构建一下,构建成功之后就会在 Workspace 看到你的项目文件被拉下来了。



那么我们的代码如何构建并且部署呢?因为我们之前在 Jenkins 的 Docker 镜像启动的时候挂载了宿主机的 Docker 程序,我们现在就可以直接基于微软的 dotnetcore 镜像来构建我们的项目。所以,我们先拉取微软的 dotnetcore 镜像,运行如下命令:

  1. docker pull microsoft/dotnet:latest

拉取镜像之后,我们来编写一个 Dockerfile 文件来让 Jenkins 来执行 Shell 构建。

如果你还不知道如何编写 Dockerfile 文件,可以参考 这篇文章

  1. FROM microsoft/dotnet:latest
  2. WORKDIR /app
  3. COPY ./ .
  4. ENV ASPNETCORE_URLS http://+:5000
  5. EXPOSE 5000
  6. RUN cd ./HKERP.IdentityServer.Host \
  7. && dotnet restore \
  8. && dotnet build
  9. WORKDIR /app/HKERP.IdentityServer.Host
  10. ENTRYPOINT ["dotnet","run"]

然后将这个 Dockerfile 放在你的项目里面,类似于这样:



然后我们再回到刚才 Jenkins 里面,配置刚才项目,新建一个 Shell Step,就像这样:



代码如下:

  1. #!/bin/sh
  2. cd /var/jenkins_home/workspace/API_IdentityServer
  3. docker container prune << EOF
  4. y
  5. EOF
  6. docker container ls -a | grep "api_identityserver"
  7. if [ $? -eq 0 ];then
  8. docker container stop api_identityserver
  9. docker container rm api_identityserver
  10. fi
  11. docker image prune << EOF
  12. y
  13. EOF
  14. docker build -t api_identityserver .
  15. docker run -d -p 8083:5000 --name=api_identityserver api_identityserver

步骤就是首先清理掉 docker 处于终止状态的容器,然后判断有没有叫 api_identityserver 的容器在运行,如果有就直接停掉,然后清除所有的虚悬镜像,使用当前目录的 dockerfile 构建一个新的 api_identityserver 镜像,使用 api_identityserver 镜像运行一个新的容器。

这儿我安装了 Jenkins 的一个 Blue Ocean 插件,来看一下:



运行一下:

[C#]使用 Jenkins 为 .Net Core 实现持续集成/部署的更多相关文章

  1. Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成——部署方案优化

    Devops 开发运维高级篇之Jenkins+Docker+SpringCloud微服务持续集成--部署方案优化 之前我们做的方案部署都是只能选择一个微服务部署并只有一台生产服务器,每个微服务只有一个 ...

  2. Centos7.4简单安装使用gitlab+maven+jenkins实现java代码的持续集成部署

    1.工具的简单介绍 gitlab--源代码版本管理控制工具 maven--java代码编译构建工具 jenkins--基于java开发的自动化持续集成部署工具 sonar--代码质量管理工具 2.gi ...

  3. Jenkins+maven+git+sonar 系统持续集成&amp;代码单測管理

    Jenkins+maven+git+sonar 系统持续集成&代码单測管理 Jenkins的安装 Jenkins是基于Java开发的一种持续集成工具,用于监控持续反复的工作.功能包含: 1.持 ...

  4. 使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(二)

    前言     上一篇随笔Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一)介绍maven和nexus的环境搭建,以及如何使用maven和nexus统一管理库 ...

  5. Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(二)

    上一篇随笔Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境(一)介绍maven和nexus的环境搭建,以及如何使用maven和nexus统一管理库文件和版本,以 ...

  6. Jenkins+Gitlab CE+Robot Framework持续集成

    环境 Ubuntu 14.04.3 LTS Desktop 前提 1.在本地能执行测试脚本(pybot yourTestSuit.txt),本文不讲解如何学习使用RF框架 2.已有Gitlab环境,本 ...

  7. 使用Maven+Nexus+Jenkins+Svn+Tomcat+Sonar搭建持续集成环境

    前言 但凡一个略有规模的项目都需要一个持续集成环境的支撑,为什么需要持续集成环境,我们来看一个例子.假如一个项目,由A.B两位程序员来协作开发,A负责前端模块,B负责后端模块,前端依赖后端.A和B都习 ...

  8. [dotnet core]落地微服务特色的DevOps管道,持续集成/部署到kubernetes。

    目录 前言 目标 工具 - 最小的学习成本 方案 - 愿景 1. 持续集成 - CI 2. 持续部署 - CD 部署环境 1. 部署gitlab-runner 2. 注册gitlab-runner 搭 ...

  9. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(二)--技术流ken

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...

随机推荐

  1. Loadrunner初学

    1.创建脚本 启动Vvitrual User Generator 创建脚本 因为我们选择录制页面相关的操作,则选择web(HTTP/HTML) application type 选择是录制浏览器网页还 ...

  2. kill-mysql-sleep.sh

    #!/bin/bash #while : #do n=`/usr/bin/mysqladmin -uroot -pXXXXX processlist | grep -i sleep | wc -l` ...

  3. maven库

    1.本地仓库 本地仓库是你本地的一个山寨版,只有你看的到,主要起缓存作用. 当你向仓库请求插件或依赖的时候,会先检查本地仓库里是否有.如果有则直接返回,否则会向远程仓库请求,并做缓存. 本地仓库默认在 ...

  4. JavaScript(第二十八天)【Cookie与存储】

    随着Web越来越复杂,开发者急切的需要能够本地化存储的脚本功能.这个时候,第一个出现的方案:cookie诞生了.cookie的意图是:在本地的客户端的磁盘上以很小的文件形式保存数据.   一.Cook ...

  5. JavaScript(第八天)【时间与日期】

    ECMAScript提供了Date类型来处理时间和日期.Date类型内置一系列获取和设置日期时间信息的方法. 一.Date类型 ECMAScript中的Date类型是在早期Java中java.util ...

  6. C语言---字符数组

    一.PTA实验作业 题目1:7-2 统计一行文本的单词个数 1. 本题PTA提交列表 2. 设计思路 定义循环变量i,j定义不为空格的字符数count,定义单词数number,i,j,count,nu ...

  7. 学号:201621123032 《Java程序设计》第4周学习总结

    1:本周学习总结 1. 写出你认为本周学习中比较重要的知识点关键词 继承,多态,父类object,抽象类 2. 尝试使用思维导图将这些关键词组织起来 2:书面作业 2.1: 面向对象设计 1. 讲故事 ...

  8. 在linux中关闭防火墙

    1) 重启后生效 开启: chkconfig iptables on 关闭: chkconfig iptables off 2) 即时生效,重启后失效 开启: service iptables sta ...

  9. Vue filter介绍及详细使用

    Vue filter介绍及其使用 VueJs 提供了强大的过滤器API,能够对数据进行各种过滤处理,返回需要的结果. Vue.js自带了一些默认过滤器例如: capitalize 首字母大写 uppe ...

  10. 为SRS流媒体服务器添加HLS加密功能(附源码)

    为SRS流媒体服务器添加HLS加密功能(附源码) 之前测试使用过nginx的HLS加密功能,会使用到一个叫做nginx-rtmp-module的插件,但此插件很久不更新了,网上搜索到一个中国制造的叫做 ...