SSIS内置的调试工具是非常完备的,对于数据流的调试,主要是设置断点和查看变量值,这是在Package的设计阶段可以使用的工具,在Package部署到服务器之后,用户还可以使用事件处理程序以实现Package出错的自我修复,使用日志记录等来监控Package的运行状态,以记录Package出现故障时的现场信息,为后续修复Package的错误提供最原始和有效的信息。当单独执行一次Package时,用户还可以为这一次执行实例设置Package级别的日志记录级别。对数据流的调试,主要是错误行和数据查看器,在数据流Task中,可以通过重定向错误行把错误保存起来,便于后续的调试和故障排除;还可以通过数据查看器,实时查看数据流中的数据,主要用于调试数据流管道。

一,设置断点

断点是调试Package时最常用的工具,Task满足中断条件时停止,为Task设置断点的手续十分简单,用户选中Task,右击选择“Edit Breakpoint”,选择中断条件,并启用断点即可。

断点的触发条件是在Task接收到特定的事件时,用户可以为一个Task设置多种中断条件的断点,常用的中断条件是:

  • Break when the container receives the OnPreExecute event
  • Break when the container receives the OnPostExecute event
  • Break when the container receives the OnError event

设置断点的向导如下图所示,用户不仅可以选择中断条件(Break Condition),还是设置条件命中的次数和类型:

在断点处,用于可以通过进行Step Into、Step Over和Step Out操作,以便逐步查看Package的运行状态,也可以按下F5,继续执行Package下面的Task。

二,查看变量值

在Packag运行到断点时,用户可以通过 Local 窗口来窗口Package中所有变量和属性的值,

Local窗口中的变量是Package中的所有变量,包括用户自定义的变量和系统变量。在调试Package时,Local窗口中的变量太多,以至于开发工程师需要浪费很多时间去查找关键的变量。一般情况下,只有很少的几个变量会影响Package运行结果,因此,开发工程师比较关注的也是这几个变量,这时,用户可以通过 Watch 窗口,手动输入变量名,重点监控这几个变量的当前值,以确认Package运行的状态:

三,事件处理程序

每一个Task和容器都会在运行时触发事件,例如,OnError事件等,事件处理程序是在特定事件被触发时,SSIS自动调用的处理程序,事件处理程序会捕获和处理相关事件。在设计Package时,开发工程师预测可能出现的异常,当异常发生时,Package自动调用事件处理程序来发送邮件通知相关人员及时修复可能存在的异常,或者重新执行Package等,以实现Package的自我修复。

事件处理程序捕获事件,而事件是由Task触发的,常用的事件是

  • OnError事件:只要发生错误都会触发该事件;
  • OnPostExecute事件:仅在Task或容器执行完成之后触发该事件;
  • OnPreExecute事件:仅在Task或容器执行之前触发该事件;

事件处理程序继承其子Task的相关事件,这意味着如果存在一个容器,并且该容器有一个针对OnError事件定义的事件处理程序,那么当该容器的一个子Task发生错误时,将会触发此容器的事件处理程序。该过程被称作“冒泡”事件,或者从子Task到容器的旅行。最高级别的可执行文件是Package本身,因此,如果在Package级别定义了一个事件处理程序,那么每当事件发生时,都会触发Package级别的事件处理程序。

四,日志记录

通常情况下,使用项目部署模型把Package部署到SSIS服务上,使用SSISDB数据库来保存Package运行的日志。如果要修改日志记录的级别,那么需要修改SSISDB的默认设置。

在Integration Services Catalogs目录下,点击SSISDB,配置Server-wide的默认日志级别。

SSIS的日志记录共有4个级别,记录的数据从少到多,依次是:

  • None:包括可执行文件、Task和参数的最小日志记录
  • Basic:默认的日志记录级别,包含None级别,以及针对特定事件的Operation的统计信息和消息;
  • Performance:包括None级别,错误和警告事件,以及为了性能优化而进行的事件上下文;
  • Verbose:记录的消息最多,最高级别的日志记录级别,记录所有的消息。

默认情况下,Package的日志记录级别和服务器级别的日志记录级别相同,用户还可以单独设置Package的日志记录级别。在Integration Services Catalogs目录中,选中某一个Package,右击弹出快捷菜单,点击“Execute”,切换到Advanced选项卡,为这一次执行实例设置日志级别。这个设置是一次性的,集成服务不会记录,Package在下次执行时,默认的日志记录级别还是和服务器级别的日志记录级别相同。

五,错误输出

在数据流中,错误行都是通过使用Error Output来配置的,这些属性高数数据流组件,当针对某一行的操作失败(出错或截断)时应该怎么做。

对错误或截断的处理程序有三种:

  • 组件失败(Fail Component):当针对某一列选择了“组件失败”,并且产生了错误时,数据流将停止运行并失败,同时触发任何针对数据流任务的OnError事件。
  • 重定向行(Redirect Row):当任何被标记为重定向的列中任何一行产生错误,整个行都将被发送到红色的错误路径输出,但是,数据流任务不会失败。如果没有使用红色的错误路径,那么该行将从数据流中丢弃。
  • 忽略失败(Ignore Failure):如果错误发生在源或转换中,那么错误列的值会被设置为NULL。如果是截断错误,那么只会向下游发送截断之后的值。当对目标进行处理时,某一列的忽略错误会导致忽略整个数据行,而不是忽略错误列。

用户可以把错误行重定向,保存到特定的数据结构中,以保存错误的数据,然后分析数据,对Package进行故障排除。

六,数据查看器

在数据流任务中,两个组件之间的连线叫做数据流路径(Data Flow Path),路径的数据查看器默认是禁用的,用户可以选中路径,右击选择“Enable Data Viewer”,启用数据查看器。

数据经过源或转换组件流向下游组件时,利用数据查看器可以实时查看数据,以检查数据是否出现异常。

Trace2:创建SQL Trace的更多相关文章

  1. SQL Server 扩展事件(Extented Events)从入门到进阶(1)——从SQL Trace到Extented Events

    由于工作需要,决定深入研究SQL Server的扩展事件(Extended Events/xEvents),经过资料搜索,发现国外大牛的系列文章,作为“学习”阶段,我先翻译这系列文章,后续在工作中的心 ...

  2. Oracle 11g R2性能优化 SQL TRACE

    作为Oracle官方自带的一种基本性能诊断工具,SQL Trace可以用来评估当前正在运行的SQL语句的效率,同时为该语句生成统计信息等,并保存这些信息到指定路径下的跟踪文件(trace)当中.SQL ...

  3. SQL Server Extended Events 进阶 1:从SQL Trace 到Extended Events

    http://www.sqlservercentral.com/articles/Stairway+Series/134869/ SQL server 2008 中引入了Extended Events ...

  4. SQL TRACE

    1.SQL TRACE说明: 参数类型 布尔型 缺省值 false 参数类别 动态 取值范围 True|false 2.类型 1)sql trace参数:alter system改变对全局进程影响,如 ...

  5. C#与数据库访问技术总结(六)之Command对象创建SQl语句代码示例

    Command对象创建SQl语句代码示例 说明:前面介绍了 Command 对象的方法和一些属性,回顾一下 Command对象主要用来执行SQL语句.利用Command对象,可以查询数据和修改数据. ...

  6. PLSQL_性能优化效能跟踪工具SQL Trace分析(案例)

    2014-06-25 Created By BaoXinjian

  7. Oracle sql trace

    一.SQL_TRACE说明 1.1.在全局启用 在参数文件(pfile/spfile)中指定:sql_trace =true 1.2.在当前session级设置 启用当前session的跟踪: alt ...

  8. SAP 使用SQL Trace(ST05)

    SAP 使用SQL Trace(ST05) SAP R/3 提供标准ABAP SQL 跟踪工具.使用T-Code:ST05 可以进入追踪设定画面:          在Trace Modes 区域中选 ...

  9. 用DBMS_ADVISOR.SQLACCESS_ADVISOR创建SQL Access Advisor访问优化建议

    使用OEM方式来创建SQL Access Advisor访问优化建议,已经是四五年的事了,下面就来写写怎样使用DBMS_ADVISOR.SQLACCESS_ADVISOR来创建SQL Access A ...

随机推荐

  1. 矩阵快速幂 HDU 4565 So Easy!(简单?才怪!)

    题目链接 题意: 思路: 直接拿别人的图,自己写太麻烦了~ 然后就可以用矩阵快速幂套模板求递推式啦~ 另外: 这题想不到或者不会矩阵快速幂,根本没法做,还是2013年长沙邀请赛水题,也是2008年Go ...

  2. 第三周作业(一):安装VS以及创建单元测试

    安装的时候找的是最新版本的VS2015,因为不想花钱也不想用破解版,所以用社区版本. 下了一个IOS文件,社区版VS2015,个人免费版,强行表示不用盗版来表现自己高尚的情操:D 放入虚拟光驱软件后, ...

  3. Meta标签介绍

    Meta标签写法与作用  meta标签是在HTML网页源代码中一个重要的html标签.meta位于head区的辅助性标签,提供用户不可用的信息.   META标签用来描述一个HTML网页文档的属性,例 ...

  4. Java_位运算(移位、位与、或、异或、非)

    public class Test { public static void main(String[] args) { // 1.左移( << ) // 0000 0000 0000 0 ...

  5. 从源代码构建 Go 开发环境

    从源代码构建 Go 开发环境 Go 1.5 之前的版本 安装C 语言开发环境 在Go 1.5 之前的版本(比如 1.3.1.4),都会部分的依赖 C 语言的工具链,所以如果你有C 语言的开发环境,就可 ...

  6. ceil 模块

    # 有时需要得到一个最小的整数,而这个数只能比自己大或相等,不能小于自己 #如: 2.1 我们需要得到的最小整数为3,即使后一位只有很小的一部分,一般用于分页 from math import cei ...

  7. MongoDB常用操作命令大全

    成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作.输入help可以看到基本操作命令,只是MongoDB没有创建数据库的命令,但有类似的命令 如:如果你想创建一个 ...

  8. JSPatch 中 defineClass 中覆盖方法的使用

    今天研究了一下JSPatch,发现好神奇好奇妙,感觉这几天我都会乐此不彼的去研究这个高大上的东西. 出处来着:https://github.com/bang590/JSPatch 简单介绍一下这个 d ...

  9. Unity3D 导航网格自动寻路(Navigation Mesh)

    NavMesh(导航网格)是3D游戏世界中用于实现动态物体自动寻路的一种技术,将游戏中复杂的结构组织关系简化为带有一定信息的网格,在这些网格的基础上通过一系列的计算来实现自动寻路..导航时,只需要给导 ...

  10. ECMAScript6 初步认识

    JavaScript由3部分组成,分别是:Dom,BOM和ECMAScript !核心(ECMAScript):由ECMA-262定义,提供核心语言功能:ECMAScript是属于国际标准化语言,所有 ...