.NET跨平臺之旅:將示例站點從ASP.NET 5 Beta5升級至Beta7

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

  • 安裝curl
    apt-get install curl
  • 安裝unzip
    apt-get install unzip
  • 安裝dnvm
    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庫。服務器

  •  apt-get install libunwind8 
  •  apt-get install libcurl3-dev 

緊接着就開始用新版的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能穩定一些。

相關文章
相關標籤/搜索