【移動應用開發(fā)技術】asp.net項目發(fā)布與部署的方法_第1頁
【移動應用開發(fā)技術】asp.net項目發(fā)布與部署的方法_第2頁
【移動應用開發(fā)技術】asp.net項目發(fā)布與部署的方法_第3頁
【移動應用開發(fā)技術】asp.net項目發(fā)布與部署的方法_第4頁
【移動應用開發(fā)技術】asp.net項目發(fā)布與部署的方法_第5頁
免費預覽已結束,剩余2頁可下載查看

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

【移動應用開發(fā)技術】項目發(fā)布與部署的方法

這篇文章主要介紹“項目發(fā)布與部署的方法”的相關知識,在下通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“項目發(fā)布與部署的方法”文章能幫助大家解決問題。發(fā)布前的設置由于新版ASP.NET5支持多版本DNX運行環(huán)境的發(fā)布和部署,所以在部署之前,我們需要設定部署的目標DNX(即之前的KRE)。步驟:右鍵BookStore項目->屬性->Application選項卡,選擇DNX的版本,本例中,選擇dnx-coreclr-win-x-beta4。在project.json文件的commands節(jié)點,我們可以看到,系統(tǒng)默認配置了3個調(diào)試命令,分別如下:命令描述web啟動WebListener服務,該服務可以讓web程序脫離IIS運行,默認地址是http://localhost:5000。gen使用該命令可以生成MVC相關的代碼,比如Controller,目前還用不到。ef

EntityFramework遷移命令,用于遷移數(shù)據(jù)使用,本例我們還用戶不到。理論上來說,我們F5運行的時候,應該是啟動web命令,但是在VS2015中,默認的運行環(huán)境依然是IISExpress,所以F5調(diào)試的時候,會默認啟動IISExpress。gen參考:/dudu/p/aspnet5-k-gen.html注意:web模式和IISExpress模式的程序運行端口不一樣。我們先F5調(diào)試運行,啟動IISExpress,打開頁面,一切正常。重新選擇默認模擬器環(huán)境為web,再F5運行,這時候發(fā)現(xiàn)彈出了一個命令行窗口,并提示如下文字:[INFORMATION:Microsoft.NET.Http.Server.WebListener]

Start

[INFORMATION:Microsoft.NET.Http.Server.WebListener]

Listening

on

prefix:

http://localhost:5000/

Started代碼沒有出錯,但是并沒有打開瀏覽器窗口,我們手工打開一個瀏覽器訪問上述網(wǎng)址,即可看到該示例程序的界面,此時說明,該BookStore已經(jīng)成功運行在5000端口了。其實該模式下的瀏覽器自動打開功能默認是關閉的,可以通過如下方式開啟自動打開功能:步驟:右鍵BookStore項目->屬性->Debug選項卡,勾選LaunchBrower復選框,并在輸入框里輸入上述網(wǎng)址即可(此時會在項目的Properties目錄下生成一個debugSettings.json文件來保存上述信息)。再次F5運行,即可看到自動打開的瀏覽器界面。應用程序參數(shù)在該Debug選項卡中,我們還看到一個應用程序參數(shù)(ApplicationArguments)輸入框,該輸入框可以傳入多種參數(shù),這些參數(shù)可以在Startup.cs里,通過Configuration的AddCommandLine方法進行收集并利用。環(huán)境變量同理,在Debug選項卡的最下面還有一個環(huán)境變量(EnvironmentVariables)輸入框,可以讓我們在調(diào)試的時候自定義一些環(huán)境變量的值(key/value),然后通過Configuration的AddEnvironmentVariables方法進行收集并利用。上述參數(shù)和環(huán)境變量的具體使用方式,請參考配置信息管理章節(jié)。發(fā)布流程分析在之前的MVC程序中,我們一般都是通過右鍵項目,選擇發(fā)布(Publish)的方式來發(fā)布程序的,這一次我們也來看看這種方式。首先,右鍵->發(fā)布->Profile(選擇FileSystem)->選擇D:\BookStore->選擇Release/coreclr->下一步,最終點擊發(fā)布。在在Output面板,我們看到出錯了,錯誤信息如下:正在連接到

D:\Documents\Visual

Studio

2015\Projects\BookStore\BookStore\..\artifacts\bin\BookStore\Release\Publish...

C:\Program

Files

(x86)\MSBuild\Microsoft\VisualStudio\v14.0\Web\Microsoft.DNX.Publishing.targets(342,5):

錯誤

:

錯誤:

無法識別規(guī)則“BackupRule”。

C:\Program

Files

(x86)\MSBuild\Microsoft\VisualStudio\v14.0\Web\Microsoft.DNX.Publishing.targets(342,5):

錯誤

:

錯誤計數(shù):

1。

C:\Program

Files

(x86)\MSBuild\Microsoft\VisualStudio\v14.0\Web\Microsoft.DNX.Publishing.targets(342,5):

錯誤

:

An

error

occured

during

publish.

The

command

["C:\Program

Files

(x86)\IIS\Microsoft

Web

Deploy\msdeploy.exe"

-source:contentPath='C:\Users\Administrator\AppData\Local\Temp\PublishTemp\'

-dest:contentPath='D:\Documents\Visual

Studio

2015\Projects\BookStore\artifacts\bin\BookStore\Release\Publish'

-verb:sync

-enableRule:DoNotDeleteRule

-retryAttempts:2

-disablerule:BackupRule

]

exited

with

code

[-1]。通過查看輸出信息,可以發(fā)現(xiàn),編譯成功,但復制的時候出錯,可能是powershell的問題,所以返回上述步驟,在設置(Settings)選項卡下,將取消發(fā)布腳本(PublishScripts)下的使用PowerShell腳本發(fā)布的復選框。重新發(fā)布,成功了。打開發(fā)布目錄D:\BookStore,發(fā)現(xiàn)生成了如下目錄和文件:目錄或文件描述approot

應用程序目錄wwwroot

靜態(tài)文件目錄genlinuxshell

命令文件gen.cmdcmd

命令文件weblinuxshell

命令文件web.cmdcmd

命令文件看到cmd文件的擴展名,我們可以猜想這些命令是用于執(zhí)行相關的命令,比如web.cmd可能就是用于啟動程序的;而非cmd擴展名文件,我們則猜想可能是用于linux/mac運行的命令。我們來試一下,點擊web.cmd文件,該文件執(zhí)行以后顯示的信息和我們在Debug程序時彈出的信息一樣,通過訪問提示中的網(wǎng)址,我們可以驗證應用程序已經(jīng)正常運行了。這種模式即時我們所說的自宿主(Self-Host)運行模式。再試一下IIS是否能夠運行該程序,將IIS站點指向到wwwroot目錄,打開網(wǎng)址,也是可以正常訪問的。打開wwwroot文件夾進行查看,靜態(tài)文件一應俱全,但是發(fā)現(xiàn)bin目錄下并沒有我們的項目DLL(BookStore.dll),而是多了一個AspNet.Loader.dll,而且根目錄下還多了一個web.config文件,內(nèi)容如下:<?xml

version="1.0"

encoding="utf-8"?>

<configuration>

<appSettings>

<add

key="bootstrapper-version"

value="1.0.0-beta4"

/>

<add

key="runtime-path"

value="..\approot\packages"

/>

<add

key="dnx-version"

value="1.0.0-beta4"

/>

<add

key="dnx-clr"

value="coreclr"

/>

<add

key="dnx-app-base"

value="..\approot\src\BookStore"

/>

</appSettings>

</configuration>通過查詢相關信息(訪問詳情),得知AspNet.Loader.dll文件只是一個橋接文件,用于接收IIS轉發(fā)過來的請求,然后將其轉交給dnx進行運行,這里的web.config里的dnx以及項目信息的配置文件是AspNet.Loader.dll在轉交請求時所需要的配置信息。通過配置文件我們可以看到,這里配置了dnx的類型、版本號,程序集的路徑和app的路徑。打開approot\src\BookStore目錄,我們發(fā)現(xiàn),這里居然都是cs源碼,雖然有個bin目錄,但是里面也沒有dll文件。而且在approot\packages文件夾下,居然有90個程序集文件夾(將近30M文件)。通過查詢網(wǎng)站的資料得知(這一部分內(nèi)容,我們在下一節(jié)進行講解),目前真正運行程序的運行環(huán)境是DNX,也被復制到approot\packages\dnx-coreclr-win-x-beta4目錄中,而該項目依賴的所有程序集(包括System開頭的)都被復制到該packages目錄下了。目的就是要做到真正的跨平臺運行,也就是說,將這些文件復制到linux系統(tǒng)下,只要有對應版本的KRE(本例中的DNX是Windows版本的)的話,就可以正常運行該程序。而bin目錄下沒有dll文件,則是使用了微軟***的動態(tài)編譯技術,即在運行的過程中,自動編譯cs文件,而且一旦修改這些cs文件的話,系統(tǒng)將會自動再次進行編譯。(感覺有點像php等腳本語言了)。雖然動態(tài)編譯很高效,但是還是沒有編譯好的dll高效,所以微軟還提供了一個選項讓開發(fā)人員在調(diào)試的時候生成dll文件。具體步驟如下:右鍵BookStore->屬性->Build選項卡,勾選編譯時生成輸出(Produceoutputsonbuild)復選框。重新編譯程序,發(fā)現(xiàn)在BookStore\artifacts\bin\BookStore\Debug目錄下的2個DNX版本文件夾下都分別生成了BookStore.dll文件了,而且還順帶了Nuget的spec文件。如果在發(fā)布的時候也要生成dll文件,則需要在發(fā)布(Publish)設置里進行修改,步驟如下:右鍵BookStore->發(fā)布(Publish)->Settings選項卡->FilePublishOptions->勾選Precompileduringpublishing復選框。這樣就可以生成響應的dll文件,但是這些dll文件依然不在wwwroot/bin目錄下,而是在approot\packages\BookStore\1.0.0目錄下,在該目錄下有2個文件夾,分別是lib和root,以及相關的Nuget的spec文件,在lib目錄下,生成的是不同dnx版本的dll文件,而root則是類似于之前的web根目錄,因為在該目錄下除了有視圖文件以外,還和以前的結構一樣,保留了bin目錄,并且在bin目錄下的Release文件夾下,也有一份針對不同dnx版本的dll文件副本。提示:上述選擇中,另外一個Deleteallexistingfilespriortopublish也可以勾選上,以便在發(fā)布時將之前發(fā)布版本的所有文件全部清空。此時,我們通過web.cmd文件或者IIS模式來驗證發(fā)布的文件,經(jīng)驗證,均可以正常運行。再仔細對比兩份不同設在的發(fā)布文件,發(fā)現(xiàn),除了dll文件以外,web.config文件的應用程序路徑也變了,即從原來的:<add

key="kre-app-base"

value="..\approot\src\BookStore"

/>變成了如下版本:<add

key="kre-app-base"

value="..\approot\packages\BookStore\1.0.0\root"

/>而web.cmd文件的內(nèi)容,也從如下內(nèi)容:@"%~dp0approot\packages\dnx-coreclr-win-x-beta4\bin\dnx.exe"

--appbase

"%~dp0approot\src\BookStore"

Microsoft.Framework.ApplicationHost

web

%*變成了如下內(nèi)容:@"%~dp0approot\packages\kre-coreclr-win-x-beta4\bin\dnx.exe"

--appbase

"%~dp0approot\packages\BookStore\1.0.0\root"

Microsoft.Framework.ApplicationHost

web

%*上述變化,我們是可以理解的,即將src源碼動態(tài)編譯運行的模式修改為預編譯dll程序集的模式。所以,在這里我們可以看到,在源碼動態(tài)編譯模式下,其發(fā)布后的文件夾結構如下://源碼動態(tài)編譯模式wwwroot/bin/Microsoft.AspNet.Loader.IIS.dll

wwwroot/Contents/site.css

wwwroot/Contents/

wwwroot/Scripts/jquery.js

wwwroot/Scripts/

approot/src/BootStore/project.json

approot/src/BootStore/

approot/src/BootStore.Data/project.json

approot/src/BootStore.Data/

approot/src/BootStore.Bussiness/project.json

approot/src/BootStore.Bussiness/

approot/packages/Elmah/{version}/

而dll預編譯模式下的發(fā)布文件夾結構如下:

//dll預編譯模式

wwwroot/bin/Microsoft.AspNet.Loader.IIS.dll

wwwroot/Contents/site.css

wwwroot/Contents/

wwwroot/Scripts/jquery.js

wwwroot/Scripts/

approot/packages/BootStore/{version}/

approot/packages/BootStore.Data/{version}/

approot/packages/BootStore.Bussiness/{version}/

approot/packages/Elmah/{version}/IIS和web.cmd模式的不同雖然我們對dnx內(nèi)容的原理不太理解,但有一點內(nèi)容,我們要記住,那就是兩種模式下,對靜態(tài)文件的訪問模式可能不太一樣。原因是因為,雖然IIS模式的根目錄就是存放靜態(tài)文件的地方,但是web.cmd文件事先啟動的卻是approot\src\BookStore目錄或approot\packages\BookStore\1.0.0\root目錄,兩個目錄下均沒有靜態(tài)文件,因為靜態(tài)文件時在wwwroot目錄下的,我們猜想,在這種模式下,肯定會有一種機制在來映射這些靜態(tài)文件,通過查找文件發(fā)現(xiàn),在approot\src\BookStore目錄下的project.json文件中的webroot鍵的值,從解決方案中默認的wwwroot變成了"../../../wwwroot",也就是說kre在映射靜態(tài)文件的時候,應該是根據(jù)這個相對目錄來查找這些文件的。同理,approot\packages\BookStore\1.0.0\root目錄下的project.json文件中的webroot鍵的值,也從wwwroot變成了"../../../../../wwwroot"(因為本來project.json文件的層級就深)。由于IIS是通過AspNet.Loader.dll做中轉,將請求轉交給DNX來運行的,那么在IIS模式下,靜態(tài)文件的請求到底是IIS來處理,還是KRE來處理呢?我們來驗證一下,

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論