概述

在 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 按特定顺序编译文件。要编译的第一批称为“顶级项”。在第一次请求之后,仅当依赖项更改时才会重新编译顶级项。

“顶级项”包括:

  • App_GlobalResources 文件夹
  • App_WebResources 文件夹
  • 配置文件属性
  • App_Code 文件夹
  • Global.asax 文件

编译顶级项后,ASP.NET 将编译其他项。包括:

  • App_LocalResources 文件夹
  • 单个 ASP.NET 页(.aspx 文件)
  • ASP.NET 用户控件(.ascx 文件)
  • ASP.NET HTTP 处理程序(.ashx 文件)
  • ASP.NET HTTP 模块(.asmx 文件)
  • 主题、母版页和其他源文件
编译输出

编译代码时,生成的程序集会缓存在服务器文件夹中。此文件夹需要适当的权限,以便代码能正确编译和运行。你可以配置编译文件夹位置以及代码编译和运行所需的权限。

  • 编译文件夹的位置

默认情况下,当您编译 Web 应用程序时,编译的代码放在 Temporary ASP.NET Files 文件夹中。此文件夹是您安装 .NET Framework 的位置的子目录。通常,位置如下:

  1. %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 属性来配置根位置。如下所示:

  1. <system.web>
  2. <compilation
  3. tempDirectory=""
  4. debug="False"
  5. strict="False"
  6. explicit="True"
  7. batch="True"
  8. batchTimeout="900"
  9. maxBatchSize="1000"
  10. maxBatchGeneratedFileSize="1000"
  11. numRecompilesBeforeAppRestart="15"
  12. defaultLanguage="vb"
  13. urlLinePragmas="False"
  14. assemblyPostProcessorType="">
  15. <assemblies>
  16. <clear />
  17. </assemblies>
  18. <buildProviders>
  19. <clear />
  20. </buildProviders>
  21. <expressionBuilders>
  22. <clear />
  23. </expressionBuilders>
  24. </compilation>
  25. </system.web>

此可选属性能指定在编译期间用于临时文件存储的目录。默认值为空字符串 ("")。若为空字符串并且当前进程具有所需的访问权限,则文件将存储在以下目录中:

  1. %FrameworkInstallLocation%\Temporary ASP.NET Files
动态编译的优劣

ASP.NET 动态编译能在部署 Web 应用程序之前修改源代码,而不必显式编译代码。如果修改源文件,则 ASP.NET 会自动重新编译该文件,并更新所有链接的资源。除非 <processModel> 一节已更改,否则 IIS 服务器不必重新启动,所做的更改即会生效。

此外,还可以通过为新文件类型创建在编译期间调用的自定义生成提供程序,来扩展 ASP.NET 生成系统。

动态编译会平均延长用户的初始响应时间,因为页和代码文件必须在首次被请求时编译。对于经常更新的大型站点来说,可能是个问题。动态编译不提供某些功能,如不能在用户访问站点之前识别编译时的 Bug。

预编译和 WebDeployment 项目

预编译

ASP.NET 可以预编译网站,然后再将其提供给用户。这样做有很多优点:

  • 由于页和代码文件在第一次被请求时无需编译,因此可以缩短对用户的响应时间。这对于更新频繁的大型网站尤为有用。
  • 可以在用户看到网站之前识别编译时的 Bug。
  • 可以创建站点的已编译版本,并将该版本部署到成品服务器,而无需使用源代码。

预编译决策。使用哪种编译模型。如下所示:

  • 快速开发应用程序而不考虑代码的编译。 使用默认编译(无预编译)。
  • 缩短对网站的首次页请求的响应时间。 使用就地预编译或部署编译选项之一。
  • 分离源代码和用户界面 (UI) 代码。 使用可更新用户界面的预编译。
  • 在不更改源代码的情况下修改 UI 代码。 使用可更新用户界面的预编译。
  • 从成品服务器移除所有源代码和用户界面代码。 使用不可更新用户界面的预编译。
  • 通过替换特定程序集来更新应用程序。 使用名称固定的预编译。
  • 使用具有强名称的程序集提高应用程序的安全性。 使用带签名程序集的预编译。
WebDeployment 项目

VS 2008 通过复制(Copy)和发布(Publish)Web网站来部署(deployment)网站。但在很多高级的情况下,开发者需要下面这些能力。

  • 更多的控制程序集的命名和输出。
  • 自定义生成(build)前和生成(build)后的处理动作。
  • 在生成(build)期间,排除、添加和转换文件和目录的能力。
  • 根据生成(build)配置,来修改 Web.config 文件以改变数据库连接字符串,应用程序设置,或是 Web 引用的 URL。例如,在开发,测试,演示和发布(release)时,使用不同的值。

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 项目(转)的更多相关文章

  1. ASP.NET MVC5 视图预编译

    ASP.NET MVC5 视图预编译 ASP.NET MVC5 视图预编译   关于Razor视图及引擎原理,就不多说了. 这里通俗或者不恰当地说,cshtml视图文件是先编译成dll文件,再通过视图 ...

  2. Asp.Net Core 禁用预编译

    在.NET Core 2 Web API应用程序中,MS VS 2017中的发布到文件夹功能产生: <ProjectAssembly>.PrecompiledViews.dll <P ...

  3. .Net Core Razor 预编译,动态编译,混合编译

    预编译 预编译是ASP .Net Core的默认方式.在发布时,默认会将系统中的所有Razor视图进行预编译.编译好的视图DLL统一命名为 xxx.PrecompiledViews.dll 或者 xx ...

  4. mybatis深入理解之 # 与 $ 区别以及 sql 预编译

    mybatis 中使用 sqlMap 进行 sql 查询时,经常需要动态传递参数,例如我们需要根据用户的姓名来筛选用户时,sql 如下: select * from user where name = ...

  5. mybatis之 # 与 $ 区别以及 sql 预编译

    mybatis 中使用 sqlMap 进行 sql 查询时,经常需要动态传递参数,例如我们需要根据用户的姓名来筛选用户时,sql 如下: select * from user where name = ...

  6. mybatis深入理解(一)之 # 与 $ 区别以及 sql 预编译

    mybatis 中使用 sqlMap 进行 sql 查询时,经常需要动态传递参数,例如我们需要根据用户的姓名来筛选用户时,sql 如下: select * from user where name = ...

  7. Mybatis参数预编译

    Mybatis参数预编译 一.数据库预编译介绍 1.数据库SQL语句编译特性: 数据库接受到sql语句之后,需要词法和语义解析,优化sql语句,制定执行计划.这需要花费一些时间.但是很多情况,我们的一 ...

  8. asp.net 预编译和动态编译

    在asp.net中,编译可以分为:动态编译Dynamical Compilation和预编译(Precompilation). 动态编译 深入剖析ASP.NET的编译原理之一:动态编译(Dynamic ...

  9. ASP.NET Core Razor 视图预编译、动态编译

    0x01 前言 ASP.NET Core在默认发布情况下,会启动预编译将试图编译成xx.Views.dll,也许在视图中打算修改一处很细小的地方我们需要再重新编译视图进行发布.下面我将从 ASP.NE ...

随机推荐

  1. (转)检测到在集成的托管管道模式下不适用的ASP.NET设置的解决方法(转)

    我们将ASP.NET程序从IIS6移植到IIS7,可能运行提示以下错误: HTTP 错误 500.23 - Internal Server Error 检测到在集成的托管管道模式下不适用的 ASP.N ...

  2. Edwin windows下基本命令:

    Ctrl-Alt-z: 对区域内所有代码求值. Ctrl-x Ctrl-e: 对光标左边或上一个表达式求值. Ctrl-c Ctrl-x: 中断当前求值. Ctrl-a: 移动到行首. Ctrl-e: ...

  3. 关于看似简单的eclipse中tomcat小猫图标消失的问题解决

    首先,这个问题出现在我新安装的虚拟机中,自己准备重新搭一套开发环境用于学习. 所以,出于好奇,自己从官网上把eclipse的最新版neo下下来尝尝鲜,刚安装好后发现与之前用的旧版基本相同,于是把相应的 ...

  4. javascript返回顶部几种代码总结

    纯js代码 /** * 回到页面顶部 * @param acceleration 加速度 * @param time 时间间隔 (毫秒) **/ function goTop(acceleration ...

  5. struct可以拥有class般的构造函数

    struct A { int a, b; A(int x, int y) :a(x), b(y){} }; int main() { A a(1, 2); cout << a.a < ...

  6. PHP数据过滤

    1.php提交数据过滤的基本原则  1)提交变量进数据库时,我们必须使用addslashes()进行过滤,像我们的注入问题,一个addslashes()也就搞定了.其实在涉及到变量取值时,intval ...

  7. python之6-5偏函数

    functools.partial 偏函数的作用是简化操作,简化什么操作呢?就是当我们有一个已知函数A,且这个函数包含有某个或多个参数A1,通过固定这个参数A1,我们可以自己编写一个新函数B,来减少代 ...

  8. git强制更新

    1.下载远程的库的内容 git fetch --all 2.把HEAD指向刚刚下载的最新的版本 git reset --hard origin/master

  9. fontresize 移动端的手机字体 大小设置

    这段js 需要置于页面上端 也就是 需要先加载js然后加载页面 (这段js是原生js而且比较短小 基本对页面加载速度无影响) FontResize : function(maxWidth){ (fun ...

  10. iOS 第三方 需要 引用的库

    ================================================== AFNetWorking   是基于 nsurlconnection   所以不需要引入库 === ...