快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

ASP技巧集锦(官方权威版)-3

 技巧 6:妙用 Session 对象
  在肯定了在 Applications 和 Sessions 中缓存的长处之后,我们建议您避免使用 Session 对象。下面将会谈到,当用于忙碌站点时,Sessions 有几个缺点。所谓忙碌,通常是指站点每秒哀求数百页或同时有数千个用户。该技巧对于必须进行水平扩展的站点,即那些利用多个服务器来适应负载或执行容错功能的站点来说,更加重要。对于较小的站点,如 intranet 站点,Sessions 的便利,与开销相比也是值得的。
  为了翻新,ASP 自动为每个访问 Web 服务器的用户创建一个 Session。每个 Session 有大约 10 KB 内存开销(在存储在 Session 中的任何数据中是最高的),并使所有的哀求都慢了一点。Session 一直保持活动状态,直到达到可配置的超时(通常 20 分钟)为止。
   Session 最大的问题不是性能而是可伸缩性。Session 不能跨越 Web 服务器;一旦在一个服务器上创建了 Session,它的数据就保持在那里。这意味着,假如您在 Web 领域中使用 Sessions,您将不得不为每个用户的哀求设计一种策略,以便始终将这些哀求引向用户的 Session 所在的服务器。这被称为将用户“粘”到 Web 服务器上。术语“粘性会话”即来源于此。由于 Session 没有保持到磁盘上,所以,当 Web 服务器崩溃时,被“粘住”的用户将丢失他们的 Sessions 状态。
  用于实施粘性会话的策略包括硬件和软件解决方案。如 Windows 2000 Advanced Server 中的网络负载平衡解决方案和 Cisco 公司的“本地指向器”解决方案可以实施粘性会话,但以牺牲一些可伸缩性为代价。这些解决方案并不完美。我们不主张您现在全盘推翻您的软件解决方案(我们过去常用 ISAPI 筛选器和 URL 矫直对方案进行检查)。
  Application 对象也不能跨越服务器;假如您需要在 Web 领域内共享并更新 Application 数据,则需要使用后端数据库。但只读的 Application 数据在 Web 领域中仍旧有用。
  假如只是为了增加正常运行时间(用于处理故障转移和服务器维护),大多数执行重要任务的站点将需要部署至少两台 Web 服务器。所以,在设计执行重要任务的应用程序时,您将需要实施“粘性会话”,或者简朴地避开 Sessions 以及其他任何在单个 Web 服务器上存储用户状态的状态治理技术。
  假如当前没有使用 Sessions,请确保将它们关闭。可以通过“Internet 服务治理器”(请参阅 ISM 文档)来为应用程序执行该操作。假如决定使用 Sessions,可以采取几个方式来将对性能的影响降低到最小。
  可以将不需要 Sessions 的内容(如“帮助”屏幕、访问者区域等)移动到关闭了 Sessions 的、单独的 ASP 应用程序中。可以逐页提示 ASP:在给定的页中您不需要 Session 对象;使用位于 ASP 页顶端的如下指令:
  <% @EnableSessionState=False %>
  使用该指令的一个很好的原因是,Session 给框架集带来了有趣的问题。ASP 保证任何时候只执行一个来自 Session 的哀求。这样可以确保假如浏览器为一个用户哀求了多个页时,在每一时刻只有一个 ASP 哀求将进入 Session;这就避免了在访问 Session 对象时出现多线程问题。遗憾的是,结果,框架集中的所有页均被以串行化方法绘制,一个接一个地,而不是同时地。这样,用户可能不得不等待很长时间才能得到所有框架内容。这意味着:假如某些框架页不信任 Session,一定要使用 @EnableSessionState=False 指令告诉 ASP。
  作为使用 Session 对象的替代方法,有很多方式可以用来治理 Session 状态。对于状态数量较小的情况(不到 4 KB),通常建议使用 Cookies、QueryString 变量和隐藏形式的变量。对于较大数量的数据,如购物推车,则使用后端数据库是最合适的选择。关于在 Web 服务器领域中的状态治理技术已经有很多资料。具体信息,请参阅 会话状态(英文)。
  
  技巧 7:在 COM 对象中封装代码
  假如您有很多 VBScript 或 JScript,那么您可以通过把代码移动到已编译的 COM 对象来常常改进它们的性能。已编译的代码通常比被解释代码运行得更快。已编译的 COM 对象可以通过“早期绑定”访问其他 COM 对象,这种调用 COM 对象方式的手段,比脚本所使用的“后期绑定”更有效。
  将代码封装在 COM 对象种有如下好处(超越性能):
  COM 对象是将表达逻辑与业务逻辑分隔开来的好办法。
  COM 对象启用了代码重用。
  很多开发商发现,用 VB、C++ 或 Visual J++ 书写的代码,比 ASP 更轻易调试。
  COM 对象有一些缺点,包括初始开发时间以及需要不同的编程技巧。需要警告您的是,封装“少”量的 ASP 可能会导致性能降低,而不是提高。通常,在少量 ASP 代码封装到 COM 对象时出现这样的情况。这时候,创建和调用 COM 对象的开销,超过了已编译代码的好处。至于 ASP 脚本和 COM 对象代码怎样合并才能产生最佳性能还有待测试。注重,与 Windows NT(R) 4.0/IIS 4.0 相比,Microsoft 已经在 Windows 2000/IIS 5.0 中极大地提高了脚本和 ADO 性能。这样,已编译代码对 ASP 代码的性能优势已经随着 IIS 5.0 的引入而降低。
  有关在 ASP 中使用 COM 对象的优缺点的更多讨论,请参阅 ASP 组件准则和用 COM 和 Microsoft Visual Basic 6.0 对分布式应用程序进行编程(英文)。假如您的确部署了 COM 组件,要对它们进行强度测试是异常重要的。实际上,所有 ASP 应用程序都应当作为正式过程进行强度测试。
  
  技巧 8:晚点获取资源,早点释放资源
  这是个小技巧。通常,最好晚点获取资源而要早点释放资源。这些资源包括 COM 对象、文件句柄和其他资源。
  ADO 连接和记录集是这种优化的首要目标。当您使用完记录集,就是说用它的数据打印完一个表格后,请立刻将它释放,而不是等到页的末尾。将您的 VBScript 变量设置为 Nothing 是最好的做法。不要让记录集简朴地脱离作用域。同时,应当释放任何有关的 Command 或 Connection 对象。(不要忘了对记录集或“连接”调用 Close(),在将它们设置为 = Nothing 之前。)这将缩短数据库必须为您调整资源的时间跨度,并将数据库连接尽可能快地释放给连接池。
返回类别: 教程
上一教程: ASP实用技巧28则
下一教程: 改进 ASP 的字符串处理性能

您可以阅读与"ASP技巧集锦(官方权威版)-3"相关的教程:
· ASP技巧集锦(官方权威版)-7
· ASP技巧集锦(官方权威版)-5
· ASP技巧集锦(官方权威版)-4
· ASP技巧集锦(官方权威版)-4
· ASP技巧集锦(官方权威版)-2
    微笑服务 优质保证 索取样品