|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
Access是一种桌面数据库,只适合数据量少的应用,在处理少量数据和单机访问的数据库时是很好的,效率也很高。但是它的同时访问客户端不能多于4个。access数据库有一定的极限,如果数据达到100M左右,很容易造成服务器iis假死,或者消耗掉服务器的内存导致服务器崩溃。技能改善功能和款式的25+ASP技能
-------------------------------
LenCardinal-MicrosoftConsultingServices初级参谋
GeorgeV.Reilly-MicrosoftIISPerformance主管
更新工夫:2000年4月
依据NancyCluts的文章(英文)改写
NancyCluts-开辟职员手艺工程师
MicrosoftCorporation
择要:本文供应了优化ASP使用程序和VBScript的技能。
目次
简介
技能1:在Web服务器上缓存经常使用数据
技能2:在Application或Session工具中缓存经常使用数据
技能3:在Web服务器磁盘上缓存数据和HTML
技能4:制止在Application或Session工具中缓存非天真组件
技能5:不要在Application或Session工具中缓存数据库毗连
技能6:妙用Session工具
技能7:在COM工具中封装代码
技能8:正点猎取资本,早点开释资本
技能9:历程外的实行将就义牢靠性
技能10:显式利用选项
技能11:在子例程和函数中利用部分变量
技能12:将经常使用数据复制到剧本变量
技能13:制止从头界说数组
技能14:利用呼应缓冲
技能15:批处置内嵌剧本和Response.Write语句
技能16:在入手下手长工夫的义务之前先利用Response.IsClientConnected
技能17:利用<OBJECT>标志实例化工具
技能18:利用ADO工具和其他组件的TypeLib绑定
技能19:使用扫瞄器的考证才能
技能20:在轮回中制止字符串串连
技能21:启用扫瞄器和代办署理缓存
技能22:尽量利用Server.Transfer替换Response.Redirect
技能23:在目次URL尾部加斜线
技能24:制止利用服务器变量
技能25:晋级为最新的和最好的版本
技能26:调剂Web服务器
技能27:举行功能测试
技能28:读取资本链接
简介
功能是一个特征。您必要事后计划功能,或是在往后从头编写使用程序。换句话说,甚么是最年夜限制优化ActiveServerPages(ASP)使用程序功能的好战略?
本文为优化ASP使用程序和“VisualBasic(R)剧本编纂器(VBScript)”供应了很多技能。对很多圈套和缺点举行了会商。本文所列的倡议均在http://www.microsoft.com及其他站点长进行了测试,并且事情一般。本文假定您对ASP开辟有基础的了解,包含对VBScript和/或JScript、ASPApplication、ASPSession和其他ASP外部工具(哀求、呼应和服务器)。
ASP的功能,一般不止取决于ASP代码自己。我们其实不想在一篇文章中包括一切的至理名言,只在最初列出与功能相干的资本。这些链接包含ASP和非ASP主题,包含“ActiveX(R)数据工具(ADO)”、“部件工具模子(COM)”、数据库和“Internet信息服务器(IIS)”设置。这些是我们喜好的链接-务请存眷它们。
技能1:在Web服务器上缓存经常使用数据
典范的ASP页从后端数据库检索数据,然后将了局转换为超文本标志言语(HTML)。不管数据库的速率怎样,从内存检索数据要比从后端数据库检索数据快很多。从当地硬盘读取数据一般也要比从数据库检索数据快很多。因而,一般能够经由过程在Web服务器(在内存或磁盘)上缓存数据来改良功能。
缓存是典范的空间与工夫的折中。假如得当地缓存数据,您将看到功能会有惊人的进步。为使缓存发扬效率,它必需坚持常常重用的数据,并且从头盘算这些数据的价值是高贵的或对照高贵的。假如缓存充斥了渣滓数据,则是对存储器的华侈。
不常常变更的数据也是缓存的候选数据,由于您不必忧虑数据与数据库的同步成绩。组合框、援用表、DHTML碎片、可扩大标志言语(XML)字符串、菜单项和站点设置变量(包含数据源称号(DSN)、Internet协定(IP)地点和Web路径)都是缓存的候选数据。注重,您能够缓存数据的暗示而不是数据自己。假如ASP页不常常变动,并且缓存的本钱也十分高(比方,全部产物目次),请思索事后天生HTML,而不是在每次哀求时从头绘制。
数据应缓存在那边,有哪些缓存战略?数据常常缓存在Web服务器内存或Web服务器磁盘上。上面两个技能会商这些选项。
技能2:在Application或Session工具中缓存经常使用数据
ASPApplication和Session工具为在内存中缓存数据供应了便利的容器。既能够将数据付与Application工具,也可将数据付与Session工具,这些数据在HTTP挪用中将保存在内存中。Session数据按用户存储,而Application数据在一切用户间共享。
什么时候将数据载进Application或Session?一般,在Application或Session启动时加载数据。要在Application或Session启动时加载数据,请鄙人面两函数中增加响应的代码:Application_OnStart()或Session_OnStart()。这两个函数应当位于Global.asa;假如没有,能够增加这些函数。也能够在第一次必要数据时加载数据。要举行上述操纵,请在ASP页中增加一些代码(或编写可重用的剧本函数),这些代码反省数据是不是存在,并在数据不存在时加载数据。这是称为缓慢盘算的典范功能手艺的例子-在您切实其实必要它之前,不举行盘算。请看例子:
<%
FunctionGetEmploymentStatusList
Dimd
d=Application("EmploymentStatusList")
Ifd=""Then
FetchEmploymentStatusList函数(不显现)
从DB中掏出数据,前往数组
d=FetchEmploymentStatusList()
Application("EmploymentStatusList")=d
EndIf
GetEmploymentStatusList=d
EndFunction
%>
能够为每块所需的数据编写相似的函数。
数据应当以甚么格局存储?任何变量范例都可存储,由于一切剧本变量是各不不异的。比方,能够存储字符串、整型或数组。一般,您将以这些变量范例之一存储ADO纪录集的内容。若要猎取ADO纪录集衍生的数据,能够手工将数据复制到VBScript变量中,每次一个字段。利用一个ADO纪录集保存函数GetRows()、GetString()或Save()(ADO2.5),会更快更烦琐。完全而具体的内容已超越了本文的局限。上面的演示函数利用了GetRows()来前往纪录集数据的数组:
取纪录集,以数组前往
FunctionFetchEmploymentStatusList
Dimrs
Setrs=CreateObject("ADODB.Recordset")
rs.Open"selectStatusName,StatusIDfromEmployeeStatus",_
"dsn=employees;uid=sa;pwd=;"
FetchEmploymentStatusList=rs.GetRows()以数组前往数据
rs.Close
Setrs=Nothing
EndFunction
对下面示例的进一步改善应该是缓存该列表的HTML,而不是缓存数组。上面是一个复杂的典范:
取纪录集,以“HTML选项”列表前往
FunctionFetchEmploymentStatusList
Dimrs,fldName,s
Setrs=CreateObject("ADODB.Recordset")
rs.Open"selectStatusName,StatusIDfromEmployeeStatus",_
"dsn=employees;uid=sa;pwd=;"
s="<selectname=""EmploymentStatus">"&vbCrLf
SetfldName=rs.Fields("StatusName")ADO字段绑定
DoUntilrs.EOF
下</p>ActiveServerPage技术为应用开发商提供了基于脚本的直观、快速、高效的应用开发手段,极大地提高了开发的效果。在讨论ASP的安全性问题之前,让我们来看看ASP是怎么工作的。 |
|