打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
如何使用ABAP异步RFC调用提升应用性能

采用如下report 研究asynchronous RFC call的性能提升:

PARAMETERS: num TYPE i OBLIGATORY DEFAULT 10.DATA:ls_line     TYPE zjerry1,     lv_start    TYPE i,     lv_end      TYPE i,     lv_taskid   TYPE c LENGTH 8,     lv_index    TYPE c LENGTH 4,     lv_finished TYPE i,     lv_count    TYPE i.START-OF-SELECTION.  PERFORM solution2.FORM solution2.  DELETE FROM zjerry1.  GET RUN TIME FIELD lv_start.  DO num TIMES.    lv_index = sy-index.    lv_taskid = 'Task' && lv_index.    CALL FUNCTION 'ZINSERT' STARTING NEW TASK lv_taskid PERFORMING callback ON END OF TASK      EXPORTING        iv_index = CONV comm_product-product_id( sy-index ).  ENDDO.  WAIT UNTIL lv_finished = num.  GET RUN TIME FIELD lv_end.  lv_end = lv_end - lv_start.  WRITE: / 'Solution2: ' , lv_end COLOR COL_NEGATIVE.  SELECT COUNT( * ) INTO lv_count FROM zjerry1.  ASSERT lv_count = num.ENDFORM.FORM callback USING p_task TYPE clike.  ADD 1 TO lv_finished.ENDFORM. function module ZINSERTmonitor的是一个比较费时的操作,在末尾会有一个DB的insertion: DATA: ls_line TYPE zjerry1,        lv_cal  TYPE timestamp,        lv_cal1 TYPE timestamp.  GET TIME STAMP FIELD lv_cal.  DO 10000 TIMES.    lv_cal = lv_cal + 1.    lv_cal = ( lv_cal * 13 ) / 12.    DO 100 TIMES.      GET TIME STAMP FIELD lv_cal1.      lv_cal = lv_cal  * 13 / 17.    ENDDO.  ENDDO.  ls_line-code_value = iv_index.  INSERT zjerry1 FROM ls_line.  ASSERT sy-subrc = 0.   COMMIT WORK AND WAIT.

DB的结构非常简单:

如果在report 里直接调用ZINSERT, response time为4.493 seconds.

如果在DO 2 TIMES里调用两次ZINSERT, 两次function module call是依次执行的,response time为8.493 seconds

如果用report 以参数2 以异步的方式调用ZINSERT 2次,report 本身的response time为3.074 seconds:

number = 3:

number = 5:


要获取更多Jerry的原创文章,请关注公众号"汪子熙":

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
多功能数字钟电路设计与制作
spilt分割文件
ALMCB3.2 控制板调试说明书(多图)
约瑟夫问题
深度探秘劳力士“水鬼”的前世今生
计算机、单片机(M16)收、发自如modbus
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服