如何衡量ASE中正在等待哪些用户进程

2020-09-11 01:01发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)使用sp_sysmon,我可以看...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


使用sp_sysmon,我可以看到有关引擎正在执行或正在等待的各种操作(尽管在默认线程模式下,如果至少有一个I/O待处理,则所有空闲引擎都将显示为I/O忙。/O忙碌着望向高位(KBA 1863319)。

我还可以看到等待引擎的"可运行任务"的数量。 我认为,这不包括等待I/O的任务。 即,我对" Runnable"的理解是指线程在队列中等待CPU(er,Core)变得可以运行该线程。

但是我看不到有什么方法可以查看哪些用户线程正在等待磁盘I/O。 我想同样的问题也适用于等待网络I/O。

与"平均可运行任务"表示"等待CPU的平均线程数"相同,应该有"等待磁盘I/O的平均线程数"和"等待网络I的平均线程数"/O"?

这是此信息的详细即时快照,但与运行总计不同:

选择描述=子字符串(b.Description,1,60),proc_count =计数(*)
 来自monProcess a,monWaitEventInfo b
 其中a.WaitEventID = b.WaitEventID
 按子字符串分组(b.Description,1,60)按count(*)desc排序

  说明proc_count
  --------------------------------------------------  ---------- -----------
  等待传入的网络数据88
  xact coord:在空闲循环4中暂停
  等待消息3
  hk:暂停一段时间3
  等待常规缓冲区读取完成3
  进程正在运行2
  检查点进程空闲循环1
  睡眠后在运行队列中等待1
  等待客户端连接请求1
  等待下一个端口管理器请求1
  桶池管理器合并器睡眠1
  等到心跳或检查间隔到期1
  等待死锁检查配置更改1

 

我认为"等待传入的网络数据"实际上是一种空闲形式,而"等待常规缓冲区读取完成"则是在等待磁盘I/O。

6条回答
jovirus
2020-09-11 01:19

好吧,我想我找到了"如何衡量ASE中等待的用户进程?"的答案。 问题。

您可以使用以下命令:

 sp_sysmon 
 

例如,要查看在1分钟的采样中各个流程的工作情况:

 sp_sysmon" 00:01:00",appmgmt,appl_and_login
 

在显示sp_sysmon输出的常规"应用程序管理"部分之后,还会显示每个应用程序/登录信息,如下所示:

 ---------------------------------------------------  --------------------------------
   应用程序->登录名:my_app_name-> my_login_name
 
   每秒每应用程序的应用程序活动计数占总数的百分比
   ------------------------- ------------ -------------  ---------
     CPU繁忙0.1 0.1 1 0.4%
     I/O忙27.9 34.9 279 99.6%
     怠速0.0 0.0 0 0.0%
 
     预定的时间25.9 32.4 259不适用
 
   每秒钟每个应用程序的应用程序优先级变化数占总数的百分比
   ------------------------- ------------ -------------  --------- ----------
   总优先级更改0.0 0.0 0不适用
 
   每秒每个actact完成的应用程序I/O总数的百分比
   ------------------------- ------------ -------------  --------- ----------
     磁盘I/O完成0.5 0.6 5 1.0%
     网络I/O完成18.2 22.8 182 35.7%
   ------------------------- ------------ -------------  ---------
   完成的I/O总数51.0 63.8 510
 
   每秒违反xact计数的资源限制占总数的百分比
   ------------------------- ------------ -------------  --------- ----------
   违反总限值0.0 0.0 0不适用
 

看上面的示例,看起来I/O Busy包括磁盘I/O 和网络I/O。

文档将" I/O忙"定义为:

" I/O忙"报告用户任务执行期间的时钟滴答数
 在采样间隔内执行I/O。  

如果某个任务正在等待 完成I/O,那么该任务是否算作I/O忙?

一周热门 更多>