Jenkins实现测试环境到生产环境一键部署(Windows)
前言:
因为dotnet在发布站点后,然后再上传服务时,会因为各种的网速问题,导致站点瞬间挂掉!那么通过一键部署,先在测试站点测试好的文件,复制到正式站点上的一个缓冲区,进行预热配置,之后再本机进行文件替换,速度是相当的快,最终把影响降到最低。
所用到的插件:
文件复制插件,从master复制到slave:【Copy Data To Workspace Plugin】:https://wiki.jenkins-ci.org/display/JENKINS/Copy+Data+To+Workspace+Plugin
注意:此插件很久没有更新,一次只能是一个目录!
前提:
必须有两台服务器,且已经配置了slave的节点,参考:(Windows)http://www.cnblogs.com/EasonJim/p/6054436.html
实现思路:
1、在测试环境应该模拟和生成环境的配置和编译版本保持是Release状态,且功能已经满足预期发布需求。
2、通过文件复制插件,复制测试环境上的部署文件到生成环境上的jenkins工作空间。
3、通过批处理处理不需要覆盖的文件或者临时要修改的配置等。
4、利用rar备份生成环境上即将要覆盖的文件,注意命名上遵循一定规律:日期-项目-文件夹-{BuildID}.bak.rar。
5、利用批处理进行从生成环境的jenkins工作空间上把文件复制到站点上,常用命令:xcopy。
具体的实现步骤:
1、在jenkins上安装【Copy Data To Workspace Plugin】文件复制插件:
【系统管理】->【管理插件】->点击【可选插件】->搜索框输入【Copy Data To Workspace Plugin】


2、新建工程,把上面实现思路配置进去:
新建项目,注意:这里要选择【构建一个自由风格的软件】,不然复制文件插件无法复制!

如果你出现了“Waiting for next available executor”,那么有可能是你选择成了【构建一个多配置项目】
进入项目详情页面,填写备注等信息,注意页面上的选择

关联这个项目这能运行在这个节点上,这里的节点的选择是通过新建节点时输入的标签名称,注意页面上的选择

选中复制文件插件,并指定要从master复制的文件夹,注意页面上的选择

添加批处理进行slave的文件夹备份,注意页面上的选择

填写备份的配处理,这里我用了RAR的压缩命令,所以如果要用RAR的时候,确保机器上已经安装。且,备份后的文件我写的比较有规律:

命令:
start c:\"Program Files"\winrar\rar.exe a -k -r -s -m1 -agYYYYMMDDHHMMSS-NN{-Admin-%BUILD_ID%.bak} {要备份到的文件夹} {要备份的文件夹}
再增加一个批处理,进行刚在master复制到slave的工作空间的文件用xcopy命令覆盖slave上的站点Admin文件夹

这里使用xcopy命令进行复制

命令:
xcopy /y /e /r {slave工作空间上的项目文件夹} {要复制到替换的文件夹}
最后【Save】,可以测试是否成功了。
注意:如果中途没有截图的选项,一般默认不选择,其实也可能根据需要进行选择。
如果想要在构建完之后,观察是否成功复制等信息,可以点【增加构建后操作步骤】来增加配置邮件的发送等操作。
后话:
有一键部署,那么肯定就有一键回滚,可以参考:http://www.cnblogs.com/EasonJim/p/5945266.html
最后是部署环境拓扑图和流程:http://www.cnblogs.com/EasonJim/p/6007669.html
Jenkins实现测试环境到生产环境一键部署(Windows)的更多相关文章
- .NET持续集成与自动化部署之路第三篇——测试环境到生产环境的一键部署策略(Windows)
Jenkins测试环境到生产环境的一键部署策略(Windows) 一.前言 前面我们已经初步实现了开发集成环境.测试环境的持续集成(自动化构建.自动化测试.自动化部署).但生产环境自动化部署迟 ...
- 转 通过 spring 容器内建的 profile 功能实现开发环境、测试环境、生产环境配置自动切换
软件开发的一般流程为工程师开发 -> 测试 -> 上线,因此就涉及到三个不同的环境,开发环境.测试环境以及生产环境,通常 ...
- 项目开发过程中什么是开发环境、测试环境、生产环境、UAT环境、仿真环境?
项目开发过程中什么是开发环境.测试环境.生产环境.UAT环境.仿真环境? 最近在公司项目开发过程中总用到测试环境,生产环境和UAT环境等,然而我对环境什么的并不是很理解它的意思,一直处于开发阶段,出于 ...
- [原创] 分享一下Sencha 三种环境(开发环境、测试环境、生产环境)的优雅配置方案
背景介绍: 在一个AspNet MVC Web API的后端Web开发项目中,使用了Sencha6.5+作为前端表现技术. 在进行两种开发框架的物理文件整合的时候,笔者不想把他俩的物理文件都“揉”在一 ...
- angular 配置开发环境、测试环境、生产环境
1. 配置开发环境.测试环境.生产环境 (1). environment.ts - 开发环境: 用于程序开发 (创建项目时自动生成) export const environment = { prod ...
- springboot项目根据不同的环境启动不同的配置,如开发环境dev,测试环境sit,生产环境application
在项目开发中,会有多个环境,如在开发环境开发完,然后在测试环境测试,最后到生产环境,每个环境的配置是不一样的,如数据库配置:还好spring提供了一个管理配置的方式:
- 分离Webpack开发环境与生产环境的配置
这是Webpack+React系列配置过程记录的第五篇.其他内容请参考: 第一篇:使用webpack.babel.react.antdesign配置单页面应用开发环境 第二篇:使用react-rout ...
- Webpack配置区分开发环境和生产环境
在项目开发的时候,我们通常会将程序分为开发环境和生产环境(或者叫线上环境),开发环境通常指的是我们正在开发的这个阶段所需要的一些环境配置,也就是方便我们开发人员调试开发的一种环境:生产环境通常指的是我 ...
- 手把手教你用webpack3搭建react项目(开发环境和生产环境)(一)
开发环境和生产环境整个配置源码在github上,源码地址:github-webpack-react 如果觉得有帮助,点个Star谢谢!! (一)是开发环境,(二)是生产环境. 一.首先创建packag ...
- webpack深入场景——开发环境和生产环境配置
以前自己写一小项目时,webpack的配置基本就是一套配置,没有考虑生产环境和开发环境的区分,最近在做一个复杂的商城项目接触到了webpack的高级配置,经过两天的研究,写出了一份目前来说比叫满意的配 ...
随机推荐
- shenben语录
1.别让别人的一句话将你击垮! 2.任何人都不能替你做决定,除了你自己! 3.对于省选: 想去就去,文化课什么的都不是问题. 如果不去,二十年后的自己一定会后悔的.
- WPF中的数据验证
数据验证 WPF的Binding使得数据能够在数据源和目标之间流通,在数据流通的中间,便能够对数据做一些处理. 数据转换和数据验证便是在数据从源到目标 or 从目标到源 的时候对数据的验证和转换. V ...
- 解决Package illuminate/html is abandoned, you should avoid using it. Use laravelcollective/html instead.问题
解决步骤: 1.分析问题是因为laravel5.1不赞成使用illuminate/html而推荐使用laravelcollective/html包,所以我们利用composer命令移除illumina ...
- node 学习笔记 - Modules 模块加载系统 (1)
本文同步自我的个人博客:http://www.52cik.com/2015/12/11/learn-node-modules-path.html 用了这么久的 require,但却没有系统的学习过 n ...
- Windows Server+AMD GPU+HDMI时_黑边_不铺满问题的解决办法
HDMI接显示器或电视,有黑边或者被放大了是个很常见的问题,显卡设置界面里改下Scale或者Overscan/Underscan就行,可问题是WindowsServer版的CCC没有控制颜色对比度和缩 ...
- [BZOJ1407][NOI2002]Savage(扩展欧几里德)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1407 分析: m,n范围都不大,所以可以考虑枚举 先枚举m,然后判定某个m行不行 某个 ...
- poj-1384 Piggy-Bank
poj-1384 Piggy-Bank 地址:http://poj.org/problem?id=1384 题意: 知道盒子里面的物体的总重量,得到每一种硬币的价格和重量,求最少钱构成盒子物体总重量的 ...
- 东大OJ-Prim算法
1222: Sweep the snow 时间限制: 1 Sec 内存限制: 128 MB 提交: 28 解决: 18 [提交][状态][讨论版] 题目描述 After the big big s ...
- jquery插件之jquery-validation
equalTo方法: equalTo: function( value, element, param ) { // Bind to the blur event of the target in o ...
- 37-wc 简明笔记
显示行数.单词数和字节数 wc [options] [file-list] 参数 file-list是wc分析的一个或多个文件的路径名列表.如果省略file-list,wc就从标准输入中读取输入 选项 ...