一个使用MSBuild Task自动编译部署的例子

2024-01-15 06:08

本文主要是介绍一个使用MSBuild Task自动编译部署的例子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用户可以根据本地文件或者SVN目录中的最新资料来进行本地编译后将Release文件自动拷贝,Web目录自动拷贝后压缩,生成Zip文件来部署。这个方法的优点是操作简单,容易和其他工具并用。
Build.bat 内容:

@ECHO   OFF
SET   / P DeployConfig = Specify build target  ( 'Production' or 'Development' )
 
IF   / NOT  '%DeployConfig%' == 'Production'  (
            
IF   / NOT  '%DeployConfig%' == 'Development'  (
                        
ECHO  Please specify Production or Development .
                        
GOTO  finish
            
)
)
 
SET   / P VersionTag = Enter SVN revision  ( e . g .   1.2 . 4 ),  or 'trunk': 
 
echo .
 
msbuild project
. msbuild  / p :VersionTag = %VersionTag% ; DeployConfig = %DeployConfig%  / nologo
 
 
rem  IF %ERRORLEVEL% GTR 0 (
rem
      ECHO.
rem
      ECHO Build failed for revision number '%VersionTag%'
rem
      ECHO.
rem
 ) ELSE (
rem
 
rem
      echo Build succeeded for revision number '%VersionTag%'
rem
 )
 
 
:finish
 
project.msbuild内容:

< Project  xmlns ="http://schemas.microsoft.com/developer/msbuild/2003"  DefaultTargets ="DeploymentZip" >
            
< PropertyGroup >
                        
< DefaultConfiguration > Release </ DefaultConfiguration >
                        
< DefaultSvnServer > 192.168.0.2 </ DefaultSvnServer >
            
</ PropertyGroup >
            
            
<!-- Choose>
                        <When Condition="'$(VersionTag)' == 'trunk'">
                                    <PropertyGroup>
                                                <RepositoryPath>svn://$(DefaultSvnServer)/MYProject/trunk</RepositoryPath>
                                    </PropertyGroup>
                        </When>
                        <Otherwise>
                                    <PropertyGroup>
                                                <RepositoryPath>svn://$(DefaultSvnServer)/MYProject/tags/$(VersionTag)</RepositoryPath>
                                    </PropertyGroup>
                        </Otherwise>
            </Choose
-->
            
            
            
<!--  Retrieve project files from source control, of the specified revision  -->
            
<!-- Target Name="SvnExport">
                        <RemoveDir Directories="buildExport" />
                        <MakeDir Directories="buildExport" />
                        
                        <SvnExport 
                                    RepositoryPath="$(RepositoryPath)/web"
                                    LocalPath="buildExport/Web"
                                    Username="deploy"
                                    Password="readonly" />
                        
                        <SvnExport 
                                    RepositoryPath="$(RepositoryPath)/api"
                                    LocalPath="buildExportAPI"
                                    Username="deploy"
                                    Password="readonly" />
            </Target
-->
            
            
< ItemGroup >
      
< WebFiles  Include ="..Web***.*"  Exclude ="..Web**.svn**;..Web***.pdb" />  
   
</ ItemGroup >
 
            
<!--  Compile API  -->
            
<!-- Target Name="API" DependsOnTargets="SvnExport" -->
            
< Target  Name ="CompileAPI" >
                        
< MSBuild 
                                    
Projects ="..APIapi.csproj"
                                    StopOnFirstFailure
="true"
                                    Properties
="Configuration=$(DefaultConfiguration)"   />               
            
</ Target >
 
 
< Target  Name ="CopyEverything"  DependsOnTargets ="CompileAPI" >
           
< RemoveDir  Directories ="buildExport"   />
           
< MakeDir  Directories ="buildExport"   />
           
< MakeDir  Directories ="buildExportWeb"   />
           
< MakeDir  Directories ="buildExportAPI"   />
           
< Copy 
                                    
SourceFiles ="..APIin$(DefaultConfiguration)MYProject.dll"  
                                    DestinationFolder
="buildExportWebin"   />
                        
< Copy 
                                    
SourceFiles ="@(WebFiles)"  
                                    DestinationFiles
="@(WebFiles->'buildExportWeb%(RecursiveDir)%(Filename)%(Extension)')"   />
 
</ Target >
 
            
< Target  Name ="CopyWebConfig"  DependsOnTargets ="CopyEverything" >
                        
< Copy 
                                    
SourceFiles ="buildExportWebConfig$(DeployConfig)Web.config"
                                    DestinationFiles
="buildExportWebWeb.config"   />
                        
< RemoveDir  Directories ="buildExportWebConfig"   />
            
</ Target >
 
<!--  Zip up all the files for transporting to deploy  -->
            
< Target 
                        
Name ="DeploymentZip"  
                        DependsOnTargets
="CopyEverything;CopyWebConfig"
                        Condition
="('$(DeployConfig)' == 'QA' OR '$(DeployConfig)' == 'Production' OR '$(DeployConfig)' == 'Development') AND '$(VersionTag)' != ''"
                        
>
 
                        
< CreateItem 
                                    
Include ="buildExportWeb**;" >
                                    
< Output  TaskParameter ="Include"  ItemName ="WebAppFiles"   />
                        
</ CreateItem >
                        
                        
< Zip 
                                    
Files ="@(WebAppFiles)"  
                                    ZipFileName
="MYProject_$(DeployConfig)_$(VersionTag).zip"
                                    WorkingDirectory
="buildExportWeb"   />
 
                        
< Message  Text ="Built deployment file with $(DefaultConfiguration) for $(DeployConfig)."   />
                        
< Message  Text ="Deployment package: MYPROJECT_$(DeployConfig)_$(VersionTag).zip"   />
                        
< Message  Text ="Done."   />
                        
            
</ Target >
 
            
< UsingTask  TaskName ="MSBuild.Community.Tasks.Subversion.SvnExport"  AssemblyFile ="$(MSBuildExtensionsPath)MSBuildCommunityTasksMSBuild.Community.Tasks.dll"   />
            
< UsingTask  TaskName ="MSBuild.Community.Tasks.Zip"  AssemblyFile ="$(MSBuildExtensionsPath)MSBuildCommunityTasksMSBuild.Community.Tasks.dll"   />
</ Project >
这2个文件没有进行优化,根据不同项目有很大改动余地。但基本功能都经过测试。在XML模式下编辑可以方便看到很多地方我都注释了,也都通过测试。相信对大多用户有所帮助。
 

这篇关于一个使用MSBuild Task自动编译部署的例子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607907

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1