在IIS中部署ASP.NET 5应用程序遭遇的问题

用VS2015中创建了一个非常简单的ASP.NET5程序:

在Startup.cs中只输入一行代码:

using System;
using Microsoft.AspNet.Builder;
using Microsoft.AspNet.Http;

namespace HellowAspNet5
{
    public class Startup
    {
        public void Configure(IApplicationBuilder app)
        {
            app.Run(context => context.Response.WriteAsync("Hello, ASP.NET 5 world!"));
        }
    }
}

将Target KRE version改为CoreCLR:

在Visual Studio中按F5能正常运行,运行结果如下:

Hello, ASP.NET 5 world!

然后尝试部署到IIS中运行,采用了2种方式:1)VS2015的Publish方式;2)手动复制文件的方式。

一、VS2015的Publish方式

发布出来有2个文件夹,一个是approot文件夹,一个是wwwroot文件夹:

将IIS站点指向wwwroot文件夹,就能正常运行。

Hello, ASP.NET 5 world!

看一下wwwroot文件夹中的内容:

神奇吧!就2个文件,一个是web.config,一个是AspNet.Loader.dll。

我写的ASP.NET5程序跑哪去了?

打开web.config一看:

<configuration>
  <appSettings>
    <add key="kpm-package-path" value="..\approot\packages" />
    <add key="bootstrapper-version" value="1.0.0-beta1" />
    <add key="kre-package-path" value="..\approot\packages" />
    <add key="kre-version" value="1.0.0-beta1" />
    <add key="kre-clr" value="CoreCLR" />
    <add key="kre-app-base" value="..\approot\src\HelloAspNet5" />
  </appSettings>
</configuration>

看到kre-app-base,似乎知道了,进入approot\src\HelloAspNet5文件夹一看:

ASP.NET5应用程序果然在这,但不是HelloAspNet5.dll(bin中也只有startup.prof),而是源代码。

难道部署ASP.NET 5应用程序要把源代码一起部署?难道ASP.NET5在运行时动态编译整个项目的源代码?不解,这个问题暂且放一边。

回过头来看一下approot文件夹,只有2个文件夹,除了刚才看过的src文件夹,剩下就是packages文件夹:

不看不知道,一看吓一跳!packages竟然有55.5M!

打开一看,哇!好多包包,数一数,有64个。看来运行ASP.NET5应用程序所需要的所有东西都在这了(除了AspNet.Loader.dll)。

再仔细一看,这么多包包中最耀眼的是一个超级豪华大包——KRE-CoreCLR-amd64.1.0.0-beta1,有50M。

这也是ASP.NET 5的一个变化,将运行环境与应用程序打包在一起,各个应用程序之间互不影响。

但是,运行一个只有写了1行代码的程序,竟然要带上64个包包,有点说不过去。

下面试试手动部署。

二、尝试手动部署

根据之前版本的ASP.NET应用程序部署经验,先得将Web项目编译成dll。但是在VS2015中即使成功编译Web项目,bin中也不会有。

后来发现在项目的Build设置中选中Produce outputs on build,可以编译出dll:

编译出来的dll在artifacts\bin中可以找到,比如这里的artifacts\bin\HelloAspNet5\Release\aspnetcore50\HelloAspNet5.dll(编译出来有162K)。

然后在IIS中新建一个站点,站点目录中就放一个bin文件夹,其中只放一个HelloAspNet5.dll文件。

访问时出现下面的错误:

HTTP Error 403.14 - Forbidden

这反过来证明AspNet.Loader.dll的用途,将它也复制到bin中。再访问,依然出错,但错误信息变了:

Couldn‘t determine an appropriate version of KRE to run.

参考第一种部署方式,通过web.config告诉AspNet.Loader所需要的KRE版本。于是添加web.config文件,添加如下的配置:

<configuration>
  <appSettings>
    <add key="kre-version" value="1.0.0-beta1" />
    <add key="kre-clr" value="CoreCLR" />
  </appSettings>
</configuration>

又出现新的错误:

Couldn‘t find package ‘KRE-CoreCLR-amd64.1.0.0-beta1‘. Locations probed:
E:\AspNet5\WebSites\packages\KRE-CoreCLR-amd64.1.0.0-beta1
E:\AspNet5\packages\KRE-CoreCLR-amd64.1.0.0-beta1
E:\packages\KRE-CoreCLR-amd64.1.0.0-beta1

找不到CoreCLR的包,从中可以看出AspNet.Loader不会在当前Web站点的目录中找,而是从上一级目录一直找到根目录。

这个问题好解决,建一个packages文件夹,将KRE-CoreCLR-amd64.1.0.0-beta1复制过来。

继续出现新的错误,而这次是让人束手无策的错误:

External component has thrown an exception.

Description: An unhandled exception occurred during the execution of the current web request.
Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.Runtime.InteropServices.SEHException: External component has thrown an exception.

Source Error:

An unhandled exception was generated during the execution of the current web request.
Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:

[SEHException (0x80004005): External component has thrown an exception.]
   System.Web.HttpRuntime.HostingInit(HostingEnvironmentFlags hostingFlags, PolicyLevel policyLevel, Exception appDomainCreationException) +361

[HttpException (0x80004005): External component has thrown an exception.]
   System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +541
   System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +122
   System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +731

然后。。。就没有然后了,昨天折腾了半天也没解决这个问题。

然后。。。今天就写了这篇随笔。

然后。。。对AspNet.Loader.dll产生了兴趣。。。

【附】目前IIS Web站点中的目录结构:

时间: 2024-10-12 21:27:12

在IIS中部署ASP.NET 5应用程序遭遇的问题的相关文章

在IIS中部署Asp.net Mvc

概述: 最近在做一个MVC 3的项目,在部署服务器时破费了一番功夫,特将过程整理下来,希望可以帮到大家! 本文主要介绍在IIS5.1.IIS6.0.IIS7.5中安装配置MVC 3的具体办法! 正文: IIS5.1 1. 安装Microsoft .net FrameWork 4.0安装包; 2. 安装ASP.NET MVC 3; 3. 在IIS中发布网站,创建虚拟目录,ASP.NET版本选择4.0.30196: 4. 添加MVC的解析: 右击IIS中的虚拟目录选择“属性”-“虚拟目录”-“配置”

Windows + IIS 环境部署Asp.Net Core App

环境:Windows Server 2012, IIS 8, Asp.Net Core 1.1. 不少人第一次在IIS中部署Asp.Net Core App的人都会遇到问题,会发现原来的部署方式无法运行Asp.Net Core App程序.过去无论是原始的Asp程序还是后来的Asp.Net程序,在IIS中的部署方式都没太大变化,仅需指向程序目录,然后设定虚拟目录,最后做一些参数配置.Asp.Net Core App为了做到跨平台,自带了一个轻量级的Web Server - Kestrel,那么要

Windows Server 2008 R2 + IIS 环境部署Asp.Net Core App

环境:Windows Server 2012, IIS 8, Asp.Net Core 1.1. 不少人第一次在IIS中部署Asp.Net Core App的人都会遇到问题,会发现原来的部署方式无法运行Asp.Net Core App程序.过去无论是原始的Asp程序还是后来的Asp.Net程序,在IIS中的部署方式都没太大变化,仅需指向程序目录,然后设定虚拟目录,最后做一些参数配置.Asp.Net Core App为了做到跨平台,自带了一个轻量级的Web Server - Kestrel,那么要

如何在IIS6,7中部署ASP.NET网站(转载)

阅读目录 查看web.config文件 在IIS中创建网站 IIS6 添加扩展名映射 IIS6 无扩展名的映射 目录的写入权限 SQL SERVER的配置 在IIS7中部署ASP.NET程序 80端口和域名 查看web.config文件 web.config通常会放在网站的根目录,这个文件中包含了一最重要的网站运行参数.比如: connectionStrings,httpHandlers,httpModules ,这些参数都是网站开发人员认为运行网站所必需的参数. 因此,如果我们想将一个网站部署

怎样在win7 IIS中部署网站?

IIS作为微软web服务器的平台,可以轻松的部署网站,让网站轻而易举的搭建成功,那么如何在IIS中部署一个网站呢,下面就跟小编一起学习一下吧. 第一步:发布IIS文件 1:发布你所要在IIS上部署的网站,在Microsoft Visual Studio中的web项目点击右键,选择发布. 2:选择文件系统,然后选择保存位置,就可以发布成部署到IIS的文件. 第二步:IIS安装(启用Windows7系统自带IIS) 1:从电脑桌面单击"开始(Start)"—单击"控制面板(Con

在IIS6,7中部署ASP.NET网站

查看web.config文件 ASP.NET网站与一般的桌面程序不同,不是拷贝过来就能运行的(数据库连接除外). 要想运行它,通常需要一些配置过程.但是,我们到底需要配置什么呢?答案是:查看web.config web.config通常会放在网站的根目录,这个文件中包含了一最重要的网站运行参数.比如: connectionStrings,httpHandlers,httpModules ,这些参数都是网站开发人员认为运行网站所必需的参数. 因此,如果我们想将一个网站部署到IIS中,必须首先打开w

深度理解IIS下部署ASP.NET Core2.1 Web应用拓扑图

原文:深度理解IIS下部署ASP.NET Core2.1 Web应用拓扑图 IIS部署ASP.NET Core2.1 应用拓扑图 我们看到相比Asp.Net, 出现了3个新的组件:ASP.NET Core Module.Kestrel.dotnet.exe, 后面我们会理清楚这三个组件的作用和组件之间的交互原理. 引入Kestrel的原因 进程内HTTP服务器,与老牌web服务器解耦,实现跨平台部署 IIS.Nginx.Apache等老牌web服务器有他们自己的启动进程和环境:为了实现跨平台部署

Web Server 在IIS上部署ASP.NET Core项目

在IIS上部署ASP.NET Core项目 一.配置应用程序池为无托管: 二.安装ASPNETCoreModule:(核心) 下载地址:https://go.microsoft.com/fwlink/?linkid=844461 安装包:DotNetCore.1.0.4_1.1.1-WindowsHosting.exe 没有安装是没有红色标记的这项的:

Docker----在Docker中部署Asp.net core2.1以及修改发布

本篇文章主要是如何在Docker容器中运行ASP.NET Core应用程序,以及修改系统之后,发布更新.本文章采用自定义的Docker文件 系统要求: 1.服务器或本地已经安装docker 一.创建一个Asp.Net Core 2.1 Web应用(若可以熟练创建项目,可忽略此节) 注意这里没有勾选 "启动Docker支持" 二.创建Docker文件 项目创建完成之后,在项目的根目录下,添加一个Dockerfile文件,注意文件名. 在Dockerfile文件中,添加如下内容 # 添加基