标签:
在 Web 服务器上,既可以部署源文件,也可以部署编译后程序集。
若部署源文件,则当用户访问时,Web 应用程序会被动态编译,并缓存该程序集,以便下次访问。
否则,若部署程序集,Web 应用程序能直接使用。
本文针对 VS 2008。Web 应用程序要想为请求提供服务,ASP.NET 必须首先分析 Web 应用程序的代码,并将其编译成一个或多个程序集。当编译代码时,会将代码编译为 Microsoft 中间语言(MSIL,与具体编程语言和 CPU 无关的语言)。运行时,MSIL 将运行在 .NET Framework 的上下文中,.NET Framework 将 MSIL 翻译成 CPU 特定的指令,以便计算机上的处理器运行应用程序。
默认情况下,当用户首次(第一次)请求资源时,如一个 ASP.NET 页(.aspx 文件),将动态编译 ASP.NET 网页和其后台代码。
第一次编译后,会缓存编译后的资源,这样将大大提高随后对同一页请求的效率。
ASP.NET 支持动态编译 ASP.NET 页(.aspx 文件)、ASP.NET Web 服务(.asmx 文件)、ASP.NET HTTP 处理程序(.ashx 文件)和 ASP.NET 应用程序文件 (Global.asax) 以及其他文件,例如它们的后台代码和 Web 应用程序的类文件。
对 Web 应用程序文件的任何更改都会自动使缓存的编译程序集无效,并触发所有受影响的资源重新编译。
当下一次向代码发出请求时,ASP.NET 会识别该代码是否已更改,并重新编译 Web 应用程序受影响的资源,使你能用最小的编译处理开销快速开发应用程序。
注意,根据对资源进行的更改情况,结果的范围可能从重新编译单个页面到重新编译整个 Web 应用程序。
在第一次对应用程序发出请求时,ASP.NET 按特定顺序编译文件。要编译的第一批称为“顶级项”。在第一次请求之后,仅当依赖项更改时才会重新编译顶级项。
“顶级项”包括:
编译顶级项后,ASP.NET 将编译其他项。包括:
编译代码时,生成的程序集会缓存在服务器文件夹中。此文件夹需要适当的权限,以便代码能正确编译和运行。你可以配置编译文件夹位置以及代码编译和运行所需的权限。
默认情况下,当您编译 Web 应用程序时,编译的代码放在 Temporary ASP.NET Files 文件夹中。此文件夹是您安装 .NET Framework 的位置的子目录。通常,位置如下:
%SystemRoot%\Microsoft.NET\Framework\versionNumber\Temporary ASP.NET Files
.NET 安装过程创建 Temporary ASP.NET Files 文件夹并为 ASP.NET 本地用户帐户分配访问权限,该帐户具有访问编译的代码所需的高信任权限。如果修改配置或帐户设置,则必须确保你使用的帐户具有访问 Temporary ASP.NET Files 文件夹的高信任权限。
ASP.NET 在 Temporary ASP.NET File 文件夹下为每个应用程序创建单独的子文件夹。可以使用配置文件的“编译”一节的 tempDirectory 属性来配置根位置。如下所示:
<system.web> <compilation tempDirectory="" debug="False" strict="False" explicit="True" batch="True" batchTimeout="900" maxBatchSize="1000" maxBatchGeneratedFileSize="1000" numRecompilesBeforeAppRestart="15" defaultLanguage="vb" urlLinePragmas="False" assemblyPostProcessorType=""> <assemblies> <clear /> </assemblies> <buildProviders> <clear /> </buildProviders> <expressionBuilders> <clear /> </expressionBuilders> </compilation> </system.web>
此可选属性能指定在编译期间用于临时文件存储的目录。默认值为空字符串 ("")。若为空字符串并且当前进程具有所需的访问权限,则文件将存储在以下目录中:
%FrameworkInstallLocation%\Temporary ASP.NET Files
ASP.NET 动态编译能在部署 Web 应用程序之前修改源代码,而不必显式编译代码。如果修改源文件,则 ASP.NET 会自动重新编译该文件,并更新所有链接的资源。除非 <processModel> 一节已更改,否则 IIS 服务器不必重新启动,所做的更改即会生效。
此外,还可以通过为新文件类型创建在编译期间调用的自定义生成提供程序,来扩展 ASP.NET 生成系统。
动态编译会平均延长用户的初始响应时间,因为页和代码文件必须在首次被请求时编译。对于经常更新的大型站点来说,可能是个问题。动态编译不提供某些功能,如不能在用户访问站点之前识别编译时的 Bug。
ASP.NET 可以预编译网站,然后再将其提供给用户。这样做有很多优点:
预编译决策。使用哪种编译模型。如下所示:
VS 2008 通过复制(Copy)和发布(Publish)Web网站来部署(deployment)网站。但在很多高级的情况下,开发者需要下面这些能力。
VS 提供的一个解决方案——Web Deployment 项目。
Web Deployment 项目是 VS 的插件包,它不会改变 VS 任何特性的行为,只是简单地添加一个额外的功能,用来 Web 站点的部署。
Web Deployment 项目是与其相关的一个 Web 站点的 MSBuild 项目,它完全集成到 VS 生成配置管理中,并为编译和部署提供配置选项,例如调试(Debug)和发布(Release)。Web Deployment项目是一个扩展,能够创建生成前(pre-build)和生成后(post-build)的动作。
Web Deployment 项目不会改变 VS 站点的生成方式。它只是 Web 站点作为输入,把产生的预编译 Web 站点作为输出,不会以任何方式改变源 Web 站点项目的文件。
ASP.NET 动态编译 http://msdn.microsoft.com/zh-cn/library/ms366723(v=VS.90).aspx
ASP.NET 预编译 http://msdn.microsoft.com/zh-cn/library/bb398860(v=VS.90).aspx
WebDeployment 项目 http://msdn.microsoft.com/en-us/library/aa479568.aspx
ASP.NET 动态编译、预编译和 WebDeployment 项目(转)
标签:
原文地址:http://www.cnblogs.com/tianma3798/p/4845877.html