如何使用ABAP异步RFC调用提升应用性能
生活随笔
收集整理的這篇文章主要介紹了
如何使用ABAP异步RFC调用提升应用性能
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
采用如下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 TASKEXPORTINGiv_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的是一個(gè)比較費(fèi)時(shí)的操作,在末尾會(huì)有一個(gè)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的結(jié)構(gòu)非常簡(jiǎn)單:
如果在report 里直接調(diào)用ZINSERT, response time為4.493 seconds.
如果在DO 2 TIMES里調(diào)用兩次ZINSERT, 兩次function module call是依次執(zhí)行的,response time為8.493 seconds
如果用report 以參數(shù)2 以異步的方式調(diào)用ZINSERT 2次,report 本身的response time為3.074 seconds:
number = 3:
number = 5:
要獲取更多Jerry的原創(chuàng)文章,請(qǐng)關(guān)注公眾號(hào)"汪子熙":
總結(jié)
以上是生活随笔為你收集整理的如何使用ABAP异步RFC调用提升应用性能的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 国内最专业的彩票系统软件 网上买彩票首选
- 下一篇: SAP ABAP SICF事务码和SAP