`

利用Powershell自动部署asp.net mvc网站项目 (一)

阅读更多

这一篇中我们会写一些关于自动化部署的代码。我们会使用 Powershell 书写这类代码。

你将发现这篇文章中涉及的东西非常具体,有的要求甚至相当苛刻且可能不具有通用性。这是因为部署从来都是跟环境打交道,部署过程中协作的组建太多,相互之间的交集不可能太大。可能唯一能够通用的是自动化部署的基本原则(只是这篇文章的基本原则):

  • 每一次自动化部署结束之后,应用程序都会有相同的初始状态。
  • 自动化部署的机器非常干净,只有相应的 Windows Server 系统和 .NET Framework。尤其是,不会有 Visual Studio。

我们需要公开一些基本的环境信息:

  • 64-bit Windows Server 2008/2012/2012 R2或者 64-bit Windows 7/8/8.1
  • 我们的工程是使用 Microsoft Visual Studio 2013 开发的;
  • .NET Framework 版本为 4.5
  • ASP.NET MVC 的版本为 5.0.0
  • Microsoft Build Tool 的版本为 12.0

关于 MSBuild 这里需要多说几句。在 Visual Studio 2013 发布之前,MSBuild 是随 .NET Framework 一起发布的。这意味着我们可以不用安装 Visual Studio 就可以构建 .NET 应用程序。

这是多么美好的世界啊!因此,上一句话是假的。尤其是当你构建 ASP.NET Web 应用程序的时候,你马上就会遇到 “Cannot found … WebApplication.target” 的错误。如果你 StackOverflow 一下就可以知道,我们需要做的是安装 Visual Studio 或者从另外一台安装了 Visual Studio 的机器上将相关的文件拷贝出来。这真是——丢人的设计!Linux 的拥趸又有了发泄的空间。

于是微软决定正视这个问题。从 Visual Studio 2013 开始,MSBuild 将与 Visual Studio 而不是.NET Framework 一起发布。这引来了一片骂声。我不得不说,大家在生活中不论遇到什么事情都要保持足够的冷静,往往先发脾气的得不到任何的好处。事实是,由于 .NET Framework 发布的周期是相对较长的,因此微软目前越来越倾向于使用 NuGet 进行类库的发布,这样有助于削减 .NET Framework 基础类库的大小,并缩短基础类库的发布周期。相应的 MSBuild 和 Visual Studio 的发布周期也希望进行独立的变化。MSBuild 将和 Visual Studio 保持发布周期的一致性,并不意味这 MSBuild 依赖于 Visual Studio。因此我们当然可以下载 MSBuild 的独立安装包 Microsoft Build Tools,并在一台没有 Visual Studio 的服务器上进行自动化构建。

再次强调,如果幸运,你可以直接运行这篇文章中的例子。但是你不要指望将这篇文章的脚本拷贝到你的工程就可以正常工作。因为部署是一个因地制宜的任务,需要具体分析。你可能会遇到各种各样的环境问题,但是我认为最重要的还是思路。

部署是什么

简单来说,部署就是 “构建(Build)” –> “拷贝” –> “配置”。那么我们就开始一个一个解决它。这一篇将着眼于构建。

编译和构建应用程序 – 思路

如何构建应用程序呢?答案是先把需要的东西都拷贝过来,然后再用工具构建。好极了,我们需要拷贝什么东西呢?当然是先把源代码拷贝过来。

┌────────────────┐
│ Src of MyApp   │
└────────────────┘

光源代码还不行,因为我们的程序依赖于第三方库(箭头代表依赖关系)。

┌────────────────┐
│ Dependent libs │
└────────────────┘
┌────────────────┐ 
│ Src of MyApp   │
└────────────────┘

例如,对于我们构建的那个简简单单的 ASP.NET MVC 5 的应用程序,我们就需要在构建之前下载它依赖的类库:

  • Microsoft.AspNet.Mvc 5.0.0
  • Microsoft.AspNet.Razor 3.0.0
  • Microsoft.AspNet.WebPages 3.0.0
  • Microsoft.Web.Infrastructure 1.0.0.0

源代码和依赖库都拷贝完了,那么接下来我们就需要将构建工具也拷贝过来:

┌────────────────┐
│ Dependent libs │
└────────────────┘
┌────────────────┐     ┌───────────────────┐
│ Src of MyApp   │────→│Tools for compiling│
└────────────────┘     └───────────────────┘

对于我们来说,构建的工具只有一个:

  • MSBuild

如今工具,源代码一应俱全,我们可以开始编译了。

安装 MSBuild

如果你做实验的机器上安装了 Visual Studio 2013——Express 版本的也是可以的——那么你可以跳过这一步,否则请下载 Microsoft Build Tools 并安装。

下载应用程序的代码

我们的代码是现成的,只需要从 git repository clone 下来就可以了。你也可以从这个地址 clone 到一个范例代码,并转换到相应的 commit。

git clone https://github.com/lxconan/MvcFromZero.git
git reset --hard 340abb32433c99975bd6485f79db6ca077119477

好了,完成了,到目前为止一切都是那么的轻松愉快。

下载应用的依赖库

我们将使用 nuget 管理包的依赖。因此我们首先要下载 NuGet 的命令行客户端,可以从这里下载。

接下来的行为都需要明确的目录结构。为了便于说明,我们将建立如下的目录结构。

MvcFromZero
 |- src
 |   |- FromZero.App
 |   |- packages
 |
 |- build
     |- tools

其中,src 目录存放 Solution 的源代码,而 build 目录存放自动化构建所需的各种工具和脚本。其中自动化构建需要的工具将放在 build/tools 目录下。因此我们也会将 nuget.exe 放在这个目录下。

接下来我们在 build 目录下建立 deploy.ps1 脚本,我们将在这个脚本中完成接下来的任务。我们先来下载依赖的包。NuGet 的包管理是通过 package.config 文件进行的。需要指出的是 package.config也具有一定的层次关系。首先 Solution 级别的包信息存储在两个地方:

  • 第一个是 Solution 目录下的 .nuget/package.config 文件,这个文件中存储的是非特定项目使用的包(如果并没有这种类型的包,则该目录不存在,或者该目录下没有任何文件);
  • 第二个是 Solution 目录下的 packages/repositories.config 文件,这个文件存储了该解决方案下的每一个工程的 packages.config 文件的路径。

而 Solution 下的每一个 Project 的包定义存储在 Project 目录下的 package.config 中。

为了下载这些依赖的包是否需要人为遍历这些 config 文件呢?原来是,而从 nuget 2.7 开始,可以直接支持 Solution 范围内的包下载,于是额我们就可以使用如下的简单函数完成包的下载了。

Function Install-SolutionPackages() {
    iex "$global_nugetPath restore $global_solutionFilePath"
}

其中,$global_nugetPath 是 nuget.exe 的路径,而 $global_solutionFilePath 是工程文件(在这里是 FromZero.App.csproj)的路径。

接下来需要确定的是构建工具的位置,我们可以使用注册表查找 MSBuild 的位置的,由于我们使用了 2013 版本的 MSBuild(Toolset 的版本号为 12.0),因此我们的查找脚本为:

Function Get-MsBuildPath() {
    $msBuildRegPath = "HKLM:\SOFTWARE\Microsoft\MSBuild\ToolsVersions\12.0"
    $msBuildPathRegItem = Get-ItemProperty $msBuildRegPath -Name "MSBuildToolsPath"
    $msBuildPath = $msBuildPathRegItem.MsBuildToolsPath + "msbuild.exe"
    return $msBuildPath
}

上述两步完成之后,就可以编译我们的工程了:

Function Compile-Project() {
    iex -Command "& '$global_msBuildPath' $project_path"
}

你迫不及待的试验了你的代码,但是却发现出了问题,MSBuild 报告无法找到Microsoft.WebApplication.targets 文件。这是怎么回事,我们已经明明在 MSBuild 中安装了Microsoft.WebApplication.targets 了啊?这是因为为了保持和 Microsoft Visual Studio 2010 SP1 的工程的兼容性,Visual Studio 2012/2013 的工程默认将 $(VisualStudioVersion) 环境变量设置为 10.0。这样,target 文件的查询路径就成了:

$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0

而不是:

$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v12.0

因此我们需要修正这个环境变量。请使用文本编辑器打开 FromZero.App.csproj 文件,找到如下的定义:

<PropertyGroup>
  <VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
  <VSToolsPath
    Condition="'$(VSToolsPath)' == ''">
    $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)
  </VSToolsPath>
</PropertyGroup>

将其中的 VisualStudioVersion 节替换为:

<VisualStudioVersion>12.0</VisualStudioVersion>

再次运行:祝贺你,你已经能够成功的下载所有的依赖,并完成工程的编译了!在本文的结束,附上 deploy.ps1 到目前为止的所有代码:

$ErrorActionPreference = 'Stop'
# Environment helpers ------------------------------------
Function Get-MsBuildPath() {
    $msBuildRegPath = "HKLM:\SOFTWARE\Microsoft\MSBuild\ToolsVersions\12.0"
    $msBuildPathRegItem = Get-ItemProperty $msBuildRegPath -Name "MSBuildToolsPath"
    $msBuildPath = $msBuildPathRegItem.MsBuildToolsPath + "msbuild.exe"
    return $msBuildPath
}
# Environment variables ----------------------------------
$global_buildDirPath = Get-Location
$global_msBuildPath = Get-MsBuildPath
$global_solutionPath = "$global_buildDirPath\..\src"
$global_solutionFilePath = "$global_solutionPath\src.sln"
$global_nugetPath = "$global_buildDirPath\tools\nuget.exe"
# Install nuget packages ---------------------------------
Function Install-SolutionPackages() {
    iex "$global_nugetPath restore $global_solutionFilePath"
}
$project_path = $global_solutionPath + '\FromZero.App\FromZero.App.csproj'
Function Compile-Project() {
    iex -Command "& '$global_msBuildPath' '$project_path'"
}
Install-SolutionPackages
Compile-Project

1
0
分享到:
评论

相关推荐

    web聊天室(.net core MVC + signalr + EF + Authorize)

    SignalR是ASP.NET Core中的一个库,专门用于实现实时双向通信。它简化了在Web应用程序中添加实时功能的过程,如聊天、协作编辑或实时通知。SignalR支持多种传输方式,包括WebSocket、Server-Sent Events(SSE)和长...

    Asp.net+Msbuild自动打包部署程序源码

    `Asp.net`与`Msbuild`结合的自动打包部署程序源码提供了一种高效、便捷的方式,以实现Web应用的自动化构建和部署。接下来,我们将深入探讨这两个技术以及它们在自动部署中的作用。 `Asp.net`是由微软开发的一种用于...

    udemy-aspnet-mvc5:ASP.NET MVC 5上的Udemy课程的练习:https:www.udemy.comcoursethe-complete-aspnet-mvc-5course

    这个压缩包文件“udemy-aspnet-mvc5-master”可能包含的是从Udemy课程中获取的ASP.NET MVC 5项目源代码,通过学习和实践这些代码,开发者可以深入理解ASP.NET MVC 5的工作机制,以及如何在实际项目中运用这一框架。...

    asp-net-mvc4-sso:示例 ASP.NET MVC4 应用程序,用于演示使用 WS-Federation 和 SAML2 的 SSO

    ASP.NET MVC4是一个流行的开发框架,用于构建动态、数据驱动的Web应用程序。在这个特定的示例项目中,它被用来演示如何实现Single Sign-On (SSO) 功能,特别是使用WS-Federation和SAML2协议。SSO允许用户在多个应用...

    [ASP.NET & IIS 7高级编程]一书光盘源码例子

    - **ASP.NET MVC**:一种基于模式的Web开发框架,用于创建可测试、可维护的Web应用。 - **ASP.NET Web API**:用于构建RESTful服务,支持HTTP协议,便于移动设备和Web应用的交互。 - **身份验证和授权**:实现用户...

    asp.net第三方插件

    7. **部署与自动化**:如Octopus Deploy和NuGet PowerShell命令,帮助开发者实现自动化部署,确保ASP.NET应用能够快速、稳定地发布到生产环境。 8. **移动支持**:对于移动友好的ASP.NET应用,第三方插件如Mobile ...

    ASP.NET源码——[CMS程序]SharpCms 0.4.0.0.zip

    通过研究和分析SharpCms的源代码,开发者可以学习到ASP.NET MVC框架的实现方式,以及如何构建一个完整的CMS系统。这有助于提升对Web开发的理解,特别是对于那些想要深入学习.NET平台和Web应用架构的人来说,这是一个...

    115_asp.net试卷生成系统_题库管理系统_试题管理.rar

    【标题】中的“115_asp.net试卷生成系统_题库管理系统_试题管理.rar”表明这是一个基于ASP.NET技术开发的在线考试系统,主要用于管理和生成试卷。系统可能包含题库管理、试题添加、编辑、删除等功能,同时也可能支持...

    ASP.NET-[CMS程序]chx99个人主页源码.zip

    ASP.NET 是微软公司推出的一种基于.NET Framework的Web应用程序开发平台,它为开发者提供了强大而高效的语言环境,如C#、VB.NET等,用于构建动态网站、Web应用程序和Web服务。本资源"ASP.NET-[CMS程序]chx99个人主页...

    微软金牌讲师、微软最有价值专家讲解WinServer2008和asp.net,PPT文件

    - **Web Forms、MVC和Web Pages**:ASP.NET支持多种开发模式,包括传统的Web Forms,模型-视图-控制器(MVC)架构,以及轻量级的Web Pages,为不同需求的开发者提供了灵活的选择。 - **AJAX支持**:ASP.NET集成了...

    秦皇岛365信息网整站打包,模板大气,简洁明了[.Net+acc]

    4. .NET源代码:网站的后端程序,可能包括ASP.NET或ASP.NET MVC等项目文件,用于处理用户请求和数据库交互。 5. 数据库文件(可能为.accdb扩展名):ACC(Access)数据库文件,存储网站所需的数据,如用户信息、文章...

    Microsoft.NET.zip

    7. **ASP.NET**:是.NET Framework的一部分,用于开发Web应用程序,提供了多种模式(MVC、Web Forms、Web API等)来构建Web应用。 8. **.NET Core**:作为.NET Framework的现代替代品,.NET Core是跨平台的,支持...

    IISl模拟软件

    1. **MVC(Model-View-Controller)架构**:ASP.NET MVC模式鼓励分离关注点,让开发者能更清晰地组织代码,提高代码的可读性和可维护性。 2. **Web Forms**:ASP.NET Web Forms提供了一种事件驱动的编程模型,类似...

    C#项目开发案例全程实

    同时,学习如何构建和部署微服务,利用C#的ASP.NET Core框架,可以实现高可扩展性和灵活性的分布式系统。 案例六:数据处理与分析。C#结合LINQ(Language Integrated Query)提供了一种强大的数据查询方式。学习...

    windows 2012 安装 .net framwork3.5报错所需的源文件

    版本3.5是在2007年发布的,它基于.NET Framework 2.0、3.0,并添加了对ASP.NET MVC、LINQ、银光(WPF)等新特性的支持。 当在Windows Server 2012上安装.NET Framework 3.5时,系统通常会尝试从Windows安装映像(也...

    C#网站开发公司管理系统。

    ASP.NET提供了丰富的功能,如页面生命周期管理、状态管理、内置的安全机制以及自动化的部署工具,使得开发者可以更高效地构建动态网站。 2. **MVC模式** 在C#网站开发中,通常会采用Model-View-Controller(MVC)...

    微软实例代码CodeFlex

    1. ASP.NET:这是微软的一个强大的Web应用程序框架,用于构建动态网站和Web应用程序。CodeFlex可能包含了不同版本的ASP.NET(如ASP.NET MVC、ASP.NET Core)的实例,涵盖了页面生命周期、控件事件处理、数据绑定、...

    Lab6dotnet:TS .NET学科的学生Mendela Alexandru-Abel的实验室6

    3. **ASP.NET**:如果项目是Web应用,可能会涉及到ASP.NET,学习如何创建Web Forms、MVC或Web API应用,以及路由、身份验证和授权等。 4. **Entity Framework**:.NET中的主流ORM(对象关系映射)工具,用于简化...

    MyPhotos_TSP.NET_Project2_WCF

    6. **UI设计**: 项目的前端可能使用ASP.NET MVC或ASP.NET Web Forms,为用户提供交互式的照片浏览和管理界面。 7. **安全性**: WCF提供了多种安全模式,如Transport、Message和TransportWithMessageCredential等,...

Global site tag (gtag.js) - Google Analytics