在上一篇教程項目管理實踐【三】每日建構【Daily Build Using CruiseControl.NET and MSBuild】 中,我們講解了如何使用CCNET+MSBuild來自動編譯項目,今天我們講解一下怎麼使用MSBuild+WebDeployment+Robocopy自動編譯過和部署ASP.NET網站。
首先安裝下面的三個軟體:
1.MSBuild.Community.Tasks下載下傳:
http://msbuildtasks.tigris.org/files/documents/3383/28296/MSBuild.Community.Tasks.msi
源代碼:
http://msbuildtasks.tigris.org/files/documents/3383/36642/MSBuild.Community.Tasks.v1.2.0.306.zip
2.WebDeployment下載下傳:
http://download.microsoft.com/download/c/c/b/ccb4877f-55f7-4478-8f16-e41886607a0e/WebDeploymentSetup.msi
3.Utility Spotlight Robocopy GUI 下載下傳:【下載下傳後,解壓後安裝,Vista不用安裝】
http://download.microsoft.com/download/f/d/0/fd05def7-68a1-4f71-8546-25c359cc0842/UtilitySpotlight2006_11.exe
安裝完成後,就開始今天的教程了。
我們以前面教程中建立的StartKit解決方案為例子,結構如下:
在上圖所示的Web項目StartKit上右鍵點選,然後點選Add Web Deployment Project…,如下圖:
彈出下面的窗體,分别輸入部署項目名稱和項目要放置的位置,如下圖:
點選OK按鈕後,解決方案的結構如下圖:
今天會講到下面二個方法,上面的步驟一樣,從這裡開始,下面的步驟有差別。
方法一:使用WebDeployment建立虛拟目錄
優點:使用簡單
缺點:功能不夠強大,隻能部署到虛拟目錄
右鍵點選部署項目,點選菜單中的Property Pages,如下圖:
在下面的窗體中,點選左側的Complication,在右側的Output Folder下的文本框中輸入編譯後網站檔案的輸出路徑:
然後,點選左側的Deploment,在右側選中Create an IIS virtual directory for the output folder前面的CheckBox,在下面的Virtual directory name下的文本框中輸入虛拟目錄的名字,Replace the existing virtual directory前面的CheckBox根據實際情況确定是否選中,如下圖:
點選确定按鈕,編譯部署項目StartKit.csproj_deploy,編譯成功後,我們打開IIS,在預設網站下可以看到虛拟目錄StartKit。OK,成功了!
方法二:使用WebDeployment+MSBuild+Robocopy
優點:功能強大
缺點:配置有點麻煩
這個方法不用配置Property Pages,直接右鍵點選StartKit.csproj_deploy項目檔案,在菜單中點選Open Project File打開部署項目檔案:
修改部署項目檔案為下面的内容:
- <!--Microsoft Visual Studio 2008 Web Deployment Project http://go.microsoft.com/fwlink/?LinkID=104956-->
- <Project ToolsVersion="3.5" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
- <PropertyGroup>
- <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
- <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
- <ProductVersion>9.0.21022</ProductVersion>
- <SchemaVersion>2.0</SchemaVersion>
- <ProjectGuid>{00000000-0000-0000-0000-000000000000}</ProjectGuid>
- <SourceWebPhysicalPath>../StartKit</SourceWebPhysicalPath>
- <SourceWebProject>{96E1A089-3FBB-4909-94F6-172665994449}|StartKit/StartKit.csproj</SourceWebProject>
- <SourceWebVirtualPath>/StartKit.csproj</SourceWebVirtualPath>
- <TargetFrameworkVersion>v3.5</TargetFrameworkVersion>
- <ProjectName>StartKit</ProjectName>
- <Major>1</Major>
- <Minor>0</Minor>
- <Revision>0</Revision>
- <VSSName>ttzhang</VSSName>
- <VSSPassword>123456</VSSPassword>
- <FtpName>anonymous</FtpName>
- <FtpPassword>anonymous</FtpPassword>
- <SmtpServerName>smtp.163.com</SmtpServerName>
- <FromAddress>[email protected]</FromAddress>
- <ToAddress>[email protected]</ToAddress>
- <MailPassword>testmail</MailPassword>
- </PropertyGroup>
- <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
- <DebugSymbols>true</DebugSymbols>
- <OutputPath>./Debug</OutputPath>
- <EnableUpdateable>true</EnableUpdateable>
- <UseMerge>true</UseMerge>
- <SingleAssemblyName>StartKit_deploy</SingleAssemblyName>
- </PropertyGroup>
- <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
- <DebugSymbols>false</DebugSymbols>
- <OutputPath>./Release</OutputPath>
- <EnableUpdateable>true</EnableUpdateable>
- <UseMerge>true</UseMerge>
- <SingleAssemblyName>StartKit_deploy</SingleAssemblyName>
- </PropertyGroup>
- <ItemGroup>
- </ItemGroup>
- <!--下面的ItemGroup節點可選,這個和項目檔案StartKit.csproj中的内容相同-->
- <ItemGroup>
- <ProjectReference Include="../BLL/BLL.csproj">
- <Project>{73A293A1-CDCC-4919-9B05-BA2531ADDB56}</Project>
- <Name>BLL</Name>
- </ProjectReference>
- <ProjectReference Include="../DAL/DAL.csproj">
- <Project>{AFF6077D-DD2D-48A0-BFAD-051BD67A6953}</Project>
- <Name>DAL</Name>
- </ProjectReference>
- <ProjectReference Include="../IBLL/IBLL.csproj">
- <Project>{620770BB-7A27-4585-9B97-44EEE349121D}</Project>
- <Name>IBLL</Name>
- </ProjectReference>
- <ProjectReference Include="../Model/Model.csproj">
- <Project>{EA43EC2E-5890-4431-BD3E-5F6C090DEA3A}</Project>
- <Name>Model</Name>
- </ProjectReference>
- </ItemGroup>
- <!--引入MSBuildCommunityTasks-->
- <Import Project="$(MSBuildExtensionsPath)/MSBuildCommunityTasks/MSBuild.Community.Tasks.Targets" />
- <!--郵件發送-->
- <!--<Target Name="EmailTest" >
- <Message Text = " Mail sending..."></Message>
- <Mail SmtpServer="$(SmtpServerName)"
- Subject="Test"
- Password="$(MailPassword)"
- From ="$(FromAddress)"
- To ="$(ToAddress)"
- Body="This is a test of the mail task." />
- </Target>-->
- <!--備份檔案到FTP-->
- <!--<Target Name="Backup" DependsOnTargets="Zip" >
- <FtpUpload UserName="$(FtpName)"
- Password="$(FtpPassword)"
- LocalFile="$(ZipFileName)"
- RemoteUri="ftp://192.168.1.2/SourceBackup/$(ZipFileName)" />
- <OnError ExecuteTargets="HandleErrorBackup" />
- </Target>-->
- <!--備份檔案到FTP失敗則發送郵件-->
- <!--<Target Name="HandleErrorBackup">
- <Message Text="Backup failed..............." />
- <Mail SmtpServer="$(SmtpServerName)"
- To="$(ToAddress)"
- From="$(FromAddress)"
- Subject="$(ProjectName) Build failed"
- Body="Backup Failure: Could not finish Backup ." />
- </Target>-->
- <!--編譯項目-->
- <Target Name="BuildProjectReferences">
- <MSBuild Projects="@(ProjectReference)" Targets="Build" />
- </Target>
- <!--生成壓縮檔案-->
- <Target Name="Zip">
- <!--時間格式-->
- <Time Format="yyyyMMddHHmmss">
- <Output TaskParameter="FormattedTime" PropertyName="buildDate"/>
- </Time>
- <Zip Files="@(ZipFiles)" ZipFileName="StartKit V$(Major)-$(Minor)-$(Revision)-$(buildDate).zip"/>
- </Target>
- <!--複制檔案-->
- <Target Name="Copy">
- <!--停止IIS服務-->
- <ServiceController ServiceName="w3svc" Action="Stop" />
- <!--使用Robocopy複制編譯後的檔案到指定位置 /XD是要忽略的檔案夾,/XF要忽略的檔案類型-->
- <Exec Command="Robocopy Debug c:/inetpub/StartKit /MIR /XD Fckeditor attachments .svn obj doc Test /XF *.zip *.wdproj *.user *.cs *.csproj" IgnoreExitCode="true" />
- <!--啟動IIS服務-->
- <ServiceController ServiceName="w3svc" Action="Start" />
- </Target>
- <!--引入WebDeployment-->
- <Import Project="$(MSBuildExtensionsPath)/Microsoft/WebDeployment/v9.0/Microsoft.WebDeployment.targets" />
- <!-- To modify your build process, add your task inside one of the targets below and uncomment it.
- Other similar extension points exist, see Microsoft.WebDeployment.targets.-->
- <Target Name="BeforeBuild"></Target>
- <Target Name="BeforeMerge"></Target>
- <Target Name="AfterMerge"></Target>
- <Target Name="AfterBuild">
- <!--編譯成功後,執行下面的Targets-->
- <!—不想生成ZIP檔案,可以注釋下面ZIP的target-->
- <CallTarget Targets="Zip"/>
- <CallTarget Targets="Copy" />
- <!--<CallTarget Targets="EmailTest"/>
- <CallTarget Targets="Backup" />-->
- </Target>
- </Project>
編譯部署項目成功後,打開C:/inetpub/StartKit檔案夾,看看是否成功複制過去了呢?好的,我去看看,哈哈,檔案果然都在,OK,成功啦!
這時候,在IIS上建立一個虛拟目錄或者網站,指向我們部署項目中指定的目錄。上一篇我們已經将該項目添加到了CCNET中,是以以後我們每次送出代碼後,MSBuild就會編譯整個解決方案【當然也會編譯部署項目】,如果編譯成功,就會自動将最新的程式部署到我們網站上。這樣就可以使網站和我們的開發實時保持同步,這隻不是唯一的實作方法,其他還有很多可以實作這個功能的方法,大家可以在這裡讨論和交流。
補充:
Microsoft Build Engine (MSBuild) 是 Microsoft 和 Visual Studio 的新的生成平台。MSBuild 在如何處理和生成軟體方面是完全透明的,使開發人員能夠在未安裝 Visual Studio 的生成實驗室環境中組織和生成産品。通過這幾篇教程,我們可以看出,MSBuild的強大功能,如果希望了解更多關于MSBuild的資訊,請檢視這裡http://msdn.microsoft.com/zh-cn/library/ms171451.aspx 。