[性能] abap运行时间分析工具se30(SAT)使用介绍

(旧)运行时间分析工具:se30
(新)运行时间分析工具:SAT
1.0 简要说明

Se30运行时分析工具,提供了详细的程序运行时环境的数据,对性能调优有很大的帮助。我们可以通过SE30分析事务代码(tcode)程序(se38)函数组(function module)的运行效率,并且可以直接对比分析SQL语句的运行情况。初始界面如下图所示。


图例1-1

如上图所示,在In Dalog栏内的(事务)(程序)(功能模块)单选一个,然后输入需要分析的程序名,事务代码或者功能模块。然后点击有运行标志的 Execute 按钮,则程序将进入正常的运行状态,在你完成运行后,程序将自动进入上去所示的界面。然后可以点击图上左下脚的 Evaluate 按钮。将进入分析评价界面,如下图所示。


图例1-2

上面的步骤基本上就完成了一个最基本到运行时分析(更详细的将下文逐一介绍)。在上图的这个界面中你可以看到程序在各个部分所消耗的时间,从而判断程序的效率。

2.0 各部分详细
2.1 计量栏内容
在图例1-1中,可以看到在计量栏下有以下2个内容。  带有指示灯的 Reliability of Time Values :在图1-1中可以看见指示灯是红色,将鼠标 停留其上可以看到显示4 processors 既为处理器的个数,点击F1,将显示以下文本。  
On some platForms, invalid time values can occur on multiprocessor machines(在多CPU的平台上,时间评估可能无效) 
In such cases, the a red traffic light is displayed. If the number of processors cannot be determined, the traffic light is set to amber(CPU数量如果未知,指示灯为红色)
The traffic light is also set to red due to incorrect times if the system is running with a debug kernel. The text "Debug kernel" is then added to the quick info for the traffic light icon.(如果系统运行在DEBUG KERNEL 鼠标停留所显示的信息为“Debug Kernel”) 
Short Descriptn : 为你的操作添加一个描述,最好写一个简要的描述,以备以后查询。 

2.2 In Parallel Session
在图1-1 中,在右边可以看见带有运行标示的 Switch on/off 按钮,点击进入 work process 界面。如下图所示。 


图例2-1

在该清单中列出了所有的  work process 。用鼠标选定一条,点击激活按钮,如果需要取消就点击取消激活,如果点击激活则,该条目有黄色三角灯亮起。在执行了一次Measurement(计量,测量)结束后,在 work process 清单中会列出完成的结果和 Measurement文件的路径,指示灯则为绿色四方灯。如果并行执行,效率会提高,并且可以查看每一个进程的runtime Measurement 结果和路径。

2.3 Schedule
在图1-1中,在右边中部可以看见带运行标示的 For User/Service 按钮,点击进入测试计划界面,如下图所示。


图例2-2 
在设定测试参数和计划日期后,凡在该日期内的执行相应程序将被记录运行时数据。该功能可用于远程跟踪某用户的实际使用情况,通过测试计划,可以实现无人值守自动化性能追踪,并且扩大测试范围。
详细说明如下:  
User: 所要记录运行时数据的用户名,既执行程序的用户名。
Client: 执行程序所在的客户端。 
External Session: 在哪个External Session 中执行的程序被记录数据。1表示只在1号进程执行的程序被记录数据,而其他的进程的不记录。0表示所有的都记录。  
Process Category: 程序的类型,Dialog,Update,RFC等。  
Object Type: Transaction, Report, Function等,与下面的对象配合,确定相应的启动方式。 
Object Name: tcode 程序名 功能函数名。  
Max. No. of Sched. Measurements: 再次统计期间,该程序的统计结果文件数,也就是 在SE30 刚进去屏幕里点击 Other File 时看到的清单中的文件数。  
Expiration Date ,Expiration Time:统计时间有效期。

2.4 Measurement Restrictions
在程序运行中可以使用变式,一般使用默认变式,其中包含了大部分程序运行时数据信息。我们也可以自己创建,更改,删除变式。具体如下图所示。


图例2-3  

在图2-3中点击创建后,将进入变式的设置界面。其中有3个tabstrip 分别是Program(parts)  Statements  Duration/Type 。   Program(parts):这个TAB的功能是设置记录那些子程序,功能函数,类的方法的 运行时数据。具体如下图。


图例2-4  

Within and below: 即某一子程序或者由它调用的所有子程序。  
Particular Unts:程序某些特定的部分运行时才会被记录数据,这些特定的部分包括  SET RUN TIME ANALYZER ON/OFF 语句之间的部分。  RFC, Update:RFC 以及 update 调用的程序也纳入数据记录范围,记录的结果将储 存在单独的文件中,这些文件同样可以在SE30中查看。  Table control :在可输入表格中从左到右字段一次是 ,类型 ,子程序名 ,本地类 名,过程类型 ,过程名。    
Statements:可以选择需要统计的ABAP语句,各项都很好理解,对于内表比较大  程序ABAP逻辑比较复杂的程序进行性能追踪的时候,这些选项将很有效果。具体如下图。


图例2-5  

Duration/Type:其中只是对运行时间的长短,文件大小进行一下设置,如下图所示。


图例2-6  

Max. size of file :  运行时数据最大长度。  
Maximum runtime: 最长运行时间,超时则终止。  
Aggregation:  统计规则(full:所有的同类语句,如同一个表内的SELECT归为一个数 据显示;
per call position:程序代码中同一个位置的调用归为一个数据显示;
None:不归纳,所有数据都单独显示)。  
With memory use(if aggretation not used):如果使用None的方式,则这个选项 将用来计算使用内存,但很消耗性能,内存占用的数据在调用的树形结构中显示。

2.5 Performance Date File
在se30的初始屏幕,有如下图的一个显示栏。


图例2-7 

在这屏幕里显示的是此次的运行时数据信息,应用程序,简短描述,测量日期,File size in KB 意思十分直白,很容易理解。具体的讲述下,Evaluate , Other File, File Info, 删除。 
Evaluate:查看此次分析的结果。运行的时间分为三个部分,分别是ABAP(ABAP代 码执行的时间),数据库(读写数据库的时间),R/3系统(R/3平台调度进程等消耗的时间)。  
Other File:打开所有系统上保存的运行时数据信息,经过选择屏幕后,可以查看或 者删除。(通过‘other files’ 你可以得到前几次测量的跟踪文件,注意,SE30的跟踪文件在8天之后将会自动被删除。另外由于跟踪文件是存储在你所登陆到的应用服务器之上的,所以你要清楚你登陆的是哪个服务器。)  
File Info:此次运行时分析数据文件信息,与性能的评测没有关系,可以忽略。  
删除:   删除此次分析结果。

2.6 命中列表  
命中列表和所在的位置看下表:


图例2-8 

命中列表与前文中提到的Aggregation方式有关,以Full Aggregation 为例从左到右。 Number: 被调用的次数。
Gross Time : 该语句,子程序以及被其调用的子程序,语句所消耗的时间。(以微秒记) 
=: 如果前后列分别为Gross Time 与 Net Time 的话,该列会显示为“=”号。 
Net time:该语句,子程序不包括被其调用的子程序,语句的消耗时间。(以微秒记)
Gross %:显示为 Gross Time 在总时间中占用的时间比。 
Net %:显示为 Net time 在总的时间中占用的时间比。
Call:语句或者子程序。  程序名   :语句或者子程序所属的程序,类名。 
Type:系统 DM 空白 分别表示ABAP运行时环境,数据库读写,ABAP代码所 消耗的时间。  Display Filter Group :显示过滤的组。

2.7 提示与技巧
在SE30 初始屏幕上的按钮,在其中提供了一些范例,可以通过比较得到更高效率的代码书写方式。也可以自己输入所需要比较的代码。具体如下图所示。



  • 2
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP是一种编程语言,用于开发SAP系统的应用程序。在使用ABAP进行开发时,可以使用一些实用工具源码来提高开发效率和质量。 首先,ABAP提供了丰富的调试工具,可以帮助开发人员在程序执行时进行调试和分析。例如,可以使用断点功能设置程序的中断点,以便在程序执行到该点时停止并进行调试。还可以使用变量监视功能来实时查看程序中各个变量的值,以便发现问题和进行调试。此外,还提供了性能分析器和SQL Trace工具,用于分析程序的性能和数据库访问情况。 其次,ABAP还提供了一些代码生成工具,可以快速生成常用的代码模板。例如,可以使用数据字典工具来创建和维护数据库表结构,节省了手动编写数据库创建语句的时间。另外,还提供了程序生成器和屏幕画面生成器,可以根据给定的输入条件自动生成相应的ABAP程序和屏幕布局,减少了手工编写重复代码的工作量。 此外,ABAP还包含了一些实用函数和类库,用于处理各种常见的编程任务。比如,可以使用字符串处理函数来对字符串进行拼接、截取、替换等操作;可以使用日期和时间函数来进行日期计算和格式转换;还可以使用表格处理函数来对内存表格进行增删改查操作。此外,还提供了各种工具类和接口,用于处理文件读写、邮件发送、Excel导入导出等功能。 总之,ABAP实用工具源码提供了一系列方便快捷的开发工具和函数库,可以帮助开发人员提高开发效率和质量。无论是调试工具、代码生成工具还是实用函数和类库,都是ABAP开发中不可或缺的工具,使得开发人员能够更加专注于业务逻辑的实现,而不用花费过多的精力在繁琐的开发细节上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值