新客网
首页 | 新闻 | 系统·网络·服务器·安全 | 工具·办公 | 编程·数据库 | 图象·网页·运营 | 硬件·存储 | 专题教程 | 论坛·old
 → 当前位置:首页 > 教程 > 数据库 > sql server > 正文

用索引调节向导调整应用程序的性能

XKER.COM   2006-12-28 11:46:27  来源:  收藏本文

你可以使用SQL服务器调节器(SQL Server Profiler)工具来收集服务器当前活动的重要信息。被这个Profiler工具所追踪到的信息(包含有数据库的真实负载)能够被用在多种场合里。现在让我们来看看如何使用Profiler收集能够被索引调节向导所使用的数据,以及你该如何使用这些工具来调试你的应用程序。

什么时候使用它?

Profiler工具能够用在数据库开发生命周期的所有阶段。例如,在初始阶段,你可以用它来辅助调试或者查明你的应用程序应该如何以及在何时调用存储过程和其他的SQL声明。在我最近所参与的一个项目里,一个已编译组件一调用数据库就超时,在这种情况下,我们使用了Profiler来辨别SQL的声明和应用程序调用它们的顺序。使用这个工具就帮助我们发现了逻辑上的错误,这样我们就成功地更正了自己的应用程序。

在开发过程后面的阶段里,Profiler能够有助于辨别负载/压力测试(load/stress testing)过程中应用程序的瓶颈。你还可以用它来监视日常的活动、执行安全审查,以及辨别其他影响性能的因素(例如设计不佳的查询)。

在Profiler里,你必须决定要记录什么,并考虑将所记录下来的服务器活动应该被保存在哪里。你可以选择将自己的追踪信息保存到数据库表格里或者是文件里。当选择将捕捉到的数据保存到表格里的时候,你还可以设置要保存数据行的最大数量。这样,Profiler就能够在一个任务繁重的系统里迅速地捕捉大量数据。但是由于这一点,你可能想要限制在一次追踪之中Profiler所要捕捉的数据总量。

你可以选择将所获得的信息保存到追踪文件里。如果选择了这个选项,你就能够在文件达到了一定的大小之后将文件信息覆盖掉,这将限制捕捉信息文件大小的上限。而且,你可以选择要从哪里开始进行追踪处理。这就非常像在应用程序层里编写代码选择是在客户端还是在服务器端进行指针执行。在正式的产品系统里,你可能不希望在服务器上放上这么一个工作负载,这样的话,让客户端处理可能就是最好的选择了。

当在这两个选项之间进行选择的时候,你的主要注意力应该放在其对数据库/应用程序性能的影响上。对于大多数类型的日志记录工作而言,将其保存为文件对系统的负担要比保存到数据库的小,所以对于高流量的实际产品系统来说,将日至保存为文件可能是更好的选择。

使用Profiler

你可以使用Profiler创建和保存能够被索引调节向导所使用的追踪结果。为了使用Profiler为向导所收集到的数据,你可以选择SQL服务器自带的缺省模板。要做到这一点,在文件(File)菜单里选择新建|追踪(New | Trace)。在常规(General)选项卡里(图A)选择用于向导的缺省模板。你就会看到可以将追踪结果保存为文件或者到数据库里。

  

图A

Profiler的常规选项卡

在事件(Events)选项卡里(图B),和向导相关联的事件类型有两个:RPC:Completed用于存储过程,以及SQL:BatchCompleted用于其他的TSQL声明。

  

图B

Profiler的事件选项卡

在使用调节器对SQL服务器的活动进行捕捉的时候,你会在一段相对较短的时间内获得大量的数据,这取决于你服务器的使用情况。所以你就应该选择只记录下你所需要的项目而不是修改缺省的模板。而且在运行Profiler的时候,你要确保在捕捉期间典型的应用程序活动会发生,这对于保证索引调节向导的质量是非常重要的,除非你是正在试图解决某个特定的问题,在后面这种情况下你要确信指定的事件正在发生。

一旦追踪被保存到文件里或者数据库表格里,你就可以回放这一过程中所发生的所有活动——设置你希望的断点——这和你使用开发人员的IDE调试器很类似。

回放Profiler的追踪内容

再次强调,捕捉到的数据会是相当多的。为了帮助限制所捕捉数据的数量,你可以定义过滤器。在定义自己的过滤器(图C)时,设置时间较长的查询是很常见的。

本新闻共2页,当前在第1页  1  2  

上一篇教程:从应用程序观SQL Server和Oracle区别
下一篇教程:没有了
收藏本文】 【我要投稿】 【打印本文】 【论坛讨论】 【关闭窗口

相关文章
·从应用程序观SQL Server和Oracle区别·使用SQL Server日志转移实现高可用性
·三步堵死网站被SQL注入的隐患!·深入浅出SQL教程之SELECT语句的自连接
·SQL Server 与Oracle的不同点(从微观上)·MySQL数据库中的安全解决方案
·深入浅出SQL教程之Group by和Having·SQL优化实例:从运行30分钟到运行只要30秒
·SQL Server数据库崩溃后的恢复之法·用PHP连mysql和oracle数据库性能比较
·构架Linux下的PHP+MySQL开发环境·Apache、SSL、MySQL和PHP平滑无缝地安装
·MySQL 专题·Debian下Mysql实践
·Linux下安PHP,APACHE,MYSQL,PERL方法·编译APACHE+PHP+MYSQL的一个脚本

学院文章搜索
  
推荐文章
·最新javascript 技巧集
·PS CS3教程:教你打造图片
·巧施妙招解决Windows2003服
·X-Window环境下配置nVIDIA
·了解进程和病毒十七点相关
·七大步骤建立可靠的Linux操
·Java路径问题最终解决方案
·P2P端口映射UPnP功能和使用
·Recover My Files让删除文
·揭开BIOS中的绝对宝藏
阅读排行
·免费代理IP(每日更新)
·端口·木马·安全·扫描应
·Windows远程控制完全指南
·一台电脑当多台用 初步体验
·QQ号码激活系统常见问题及
·妙用ISEE三步将女友照片变
·解除关机后鼠标还亮的问题
·IP地址冲突问题的解决和预
·还原我的系统Win XP恢复全
·SQL优化实例:从运行30分钟
专题教程
·photoshop抠图教程
·PHP教程专题
·MySQL 专题
·数据恢复指南 专题
·Web服务器专题
·DB2 9数据库专题
·ghost教程 专题
·局域网技术专题
·虚拟机专题
·CDN加速技术专题
最新文章
·用索引调节向导调整应用程
·从应用程序观SQL Server和
·使用SQL Server日志转移实
·网管必学:拒绝捣蛋,屏蔽
·用Fireworks做出精美的文字
·台湾地震让1500万人上不了
·用自己喜欢的照片DIY个性新
·三组网站经常使用的流行色
·改改小小细节 Excel表格立
·讲解交换机配置之Telnet方
·六大绝招教你给网络设备做
·从网络管理来看病毒与数据
·网管员十大招解决服务器管
·提示“虚拟内存”不足的怎
·百度在华领先优势缩小
设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003 - 2006 XKER Inc. All Rights Reserved
新客网 版权所有