|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
技巧 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 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |