9月2日,微軟發佈了ASP.NET 5 Beta7(詳見Announcing Availability of ASP.NET 5 Beta7)。其中最大的亮點是dnx已經能夠徹底基於CoreCLR運行,也就是在Mac/Linux上運行dnx無需再借助Mono,而以前必須安裝Mono,才能運行dnu restore安裝nuget包包。html
咱們的ASP.NET 5跨平臺示例站點 about.cnblogs.com 以前是跑在 ASP.NET 5 Beta5 上的(詳見藉助ASP.NET 5 Beta5的新特性顯示CLR與操做系統信息)。2個月跑下來,最大的感覺是Kestrel太不穩定了,幾乎每天都會掛掉。linux
今天咱們決定將示例站點從ASP.NET 5 Beta5升級至Beta7,這篇博文主要分享的是升級操做步驟以及遇到的問題。git
此次咱們將服務器操做系統從CentOS換成了Ubuntu。github
首先安裝的是dnvm,安裝步驟以下:web
apt-get install curl
apt-get install unzip
curl -sSL https://raw.githubusercontent.com/aspnet/Home/dev/dnvminstall.sh | DNX_BRANCH=dev sh && source ~/.dnx/dnvm/dnvm.sh
接下來是安裝dnx:json
安裝命令:api
# dnvm upgrade -r coreclr
安裝結果:瀏覽器
Determining latest version Latest version is 1.0.0-beta7 Downloading dnx-coreclr-linux-x64.1.0.0-beta7 from https://www.nuget.org/api/v2 Download: https://www.nuget.org/api/v2/package/dnx-coreclr-linux-x64/1.0.0-beta7 ######################################################################## 100.0% Installing to /root/.dnx/runtimes/dnx-coreclr-linux-x64.1.0.0-beta7
再接下來就是安裝運行dnu restore命令所需的Linux庫。服務器
緊接着就開始用新版的dnx運行示例站點所在的ASP.NET 5項目。curl
首先用dnu restore安裝nuget包包,運行成功,結果以下:
# dnu restore Microsoft .NET Development Utility CoreCLR-x64-1.0.0-beta7-15532 GET https://api.nuget.org/v3/index.json OK https://api.nuget.org/v3/index.json 5354ms Restoring packages for /data/AboutUs/project.json ... Installed: 256 package(s) to /root/.dnx/packages
接下來就是用dnx命令運行站點,從Beta 7開始在當前目錄運行不須要輸入點號了,只需下面的命令:
dnx kestrel
運行站點首先遇到的錯誤:
System.MissingMethodException: Method not found: 'Microsoft.Framework.Configuration.IConfiguration Microsoft.Framework.Configuration.IConfigurationBuilder.Build()'. at Microsoft.AspNet.Hosting.Program.Main(String[] args)
這是因爲kestrel包包更名了,由Kestrel改成了Microsoft.AspNet.Server.Kestrel,因此要在project.json中改一下。
{ "webroot": "wwwroot", "exclude": ["wwwroot"], "commands":{ "kestrel": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.Kestrel --server.urls http://localhost:8001" }, "dependencies":{ "Microsoft.AspNet.Server.Kestrel": "1.0.0-*", "Microsoft.AspNet.Mvc": "6.0.0-*", "Microsoft.AspNet.StaticFiles": "1.0.0-*", "Microsoft.AspNet.Diagnostics": "1.0.0-*", "System.Runtime.Serialization.Primitives": "4.0.10-*" } }
繼續運行dnx kestrel,出現新的錯誤:
/data/AboutUs/Extensions/HtmlHelperExtensions.cs(21,24): DNXCore,Version=v5.0 error CS0266: Cannot implicitly convert type 'Microsoft.AspNet.Html.Abstractions.IHtmlContent' to 'Microsoft.AspNet.Mvc.Rendering.HtmlString'. An explicit conversion exists (are you missing a cast?)
這是因爲新版的ASP.NET MVC中IHtmlHelper.Raw返回值的類型由HtmlString改成了IHtmlContent,因此要改一下錯誤中提到的擴展方法的返回值類型。
public static class HtmlHelperExtensions { public static IHtmlContent TabLink(this IHtmlHelper htmlHelper, string linkText, string linkUrl, string viewName) { //... } }
而且要添加一個命名空間——using Microsoft.AspNet.Html.Abstractions;
繼續運行,繼續錯誤:
Unable to load libuv. Make sure libuv is installed and available as libuv.so.1 at Microsoft.AspNet.Server.Kestrel.Networking.Libuv.Load(String dllToLoad)
這是因爲Kestrel須要libuv才能運行,依次運行下面的命令安裝libuv:
apt-get install make automake libtool curl -sSL https://github.com/libuv/libuv/archive/v1.4.2.tar.gz | sudo tar zxfv - -C /usr/local/src cd /usr/local/src/libuv-1.4.2 sh autogen.sh ./configure make make install rm -rf /usr/local/src/libuv-1.4.2 && cd ~/ ldconfig
安裝好libuv以後,終於成功運行起了站點!
# dnx kestrel Application started. Press Ctrl+C to shut down.
可是用瀏覽器訪問站點,卻出現下面的錯誤:
The type or namespace name 'Runtime' does not exist in the namespace 'Microsoft.Framework' (are you missing an assembly reference?) public Microsoft.Framework.Runtime.IRuntimeEnvironment env { get; private set; }
這是發生在MVC視圖中的錯誤,也是更名惹的禍,IRuntimeEnvironment全部的命名空間由原來的Microsoft.Framework.Runtime被改成了Microsoft.Dnx.Runtime,因此視圖中要改成如下的代碼 :
@inject Microsoft.Dnx.Runtime.IRuntimeEnvironment env
解決這個問題以後, 站點 about.cnblogs.com 能正常訪問了,升級也就成功完成了!
但願新版Kestrel能穩定一些。