前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用Asynchronous RFC call 拆分time consuming task

使用Asynchronous RFC call 拆分time consuming task

作者头像
Jerry Wang
发布2019-07-03 11:19:50
4920
发布2019-07-03 11:19:50
举报

Created by Jerry Wang, last modified on May 05, 2014 Go to start of metadata

设计一个function module 模拟一个比较花费CPU计算时间的time consuming task.

FUNCTION zinsert.
*"----------------------------------------------------------------------
*"*"Local Interface:
*"  IMPORTING
*"     VALUE(IV_INDEX) TYPE  COMM_PRODUCT-PRODUCT_ID
*"----------------------------------------------------------------------


  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.

ENDFUNCTION.

在function 执行末尾会有一个database 的insert operation. Database table structure如下:

image
image

下面的report可以比较两种调用ZINSERT 方式的性能差异.

方法1是在循环里顺序调用ZINSERT,每次function call结束之后再进行下一次function调用。方法二是采用asynchronous RFC call的方式来并发操作.

两种方式的性能差异见如下图:

image
image
REPORT ztable.

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 solution1.
  PERFORM solution2.

FORM solution1.
  DELETE FROM zjerry1.
  GET RUN TIME FIELD lv_start.
  DO num  TIMES.
    CALL FUNCTION 'ZINSERT'
      EXPORTING
        iv_index = CONV comm_product-product_id( sy-index ).
  ENDDO.

  GET RUN TIME FIELD lv_end.

  lv_end = lv_end - lv_start.

  WRITE: / 'solution1: ' , lv_end COLOR COL_NEGATIVE.
ENDFORM.

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.
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年07月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Created by Jerry Wang, last modified on May 05, 2014 Go to start of metadata
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档