[转帖]SAP R3和JAVA交换数据之JCO _Hadoop,ERP及大数据讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Hadoop,ERP及大数据讨论区 »
总帖数
2
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4340 | 回复: 1   主题: [转帖]SAP R3和JAVA交换数据之JCO         上一篇   下一篇 
    本主题由 koei123 于 2015-2-5 17:26:09 移动
nini
注册用户
等级:新兵
经验:56
发帖:63
精华:0
注册:2011-12-16
状态:离线
发送短消息息给nini 加好友    发送短消息息给nini 发消息
发表于: IP:您无权察看 2014-12-26 11:20:20 | [全部帖] [楼主帖] 楼主

SAP Java Connector (JCo)


SAP的JAVA中间件,使用它可以使SAP的客户和合作伙伴使用JAVA语言轻松地建立可以和SAP系统通信的兼容的组件和应用程序下面是JCo一些显著的特征:

1.      支持双向调用(ABAP调用JAVA和JAVA调用ABAP)

2.      支持Unicode和非Unicode编码的系统

3.      为程序员封装了一些难以理解和处理的部分,比如代码页,数据类型转换和连接池等等

4.      屏蔽了RFC和DDIC的一些细节,这样可以让程序员专注于业务逻辑的处理,而不必去理会过于底层的东西

5.      容易学习和使用的API和JAVA类的设计

6.      动态查找和缓存元数据

Java应用程序使用JCo的API进行连接,RFC中间件使用RFC库通过JNI来连接SAP的R/3系统,如下图所示:

连接过程:

1.      创建一个连接池 addClientPool()

2.      创建一个BOR,它包含运行时环境所有function模块的元数据 createRepository()

3.      创建function template getFunctionTemplate()

4.      创建function getFunction()

5.      从连接池中取出一个连接的实例 getClient()

6.      设置传递给function模块的输入参数 getImportParameterList()

7.      执行这个function excute()

8.      得到function执行后得到的输出参数 getExportParameterList()

9.      销毁连接池 removeClientPool()

性能优化注意事项

1.      因为连接池中的连接是可重用和可保持的,所以可以降低系统开销,最大并发连接数量的限制避免过多地占用SAP系统的资源,尽管如此,也不要使用过小的最大并发连接数从而造成应用系统的性能瓶颈,为了容纳由应用系统造成的额外负载,SAP系统要经过一些配置。

2.      使用一个新的function对象时,为了提高性能而重用已有的function对象,不仅是多于的,而且还很危险,因为JCo的Repository为每个function模块缓存了元数据,如果重用一个含有表参数的function,而这个function中的表中的行数据没有被清除,那么更多的行数据会添加到这个表上,从而会造成错误的结果,这是使用一个新的function对象时要注意的。

3.      只需使用一个Repository对象,因为Repository对象可以动态重新得到SAP function模块中的元数据并重新缓存,所以使用一个就够了,如果使用过多的Repository对象,会降低应用系统和SAP系统的性能

4.      应用系统只使用了function中的一小部分参数,为了提高性能,可以使用setActive()方法将那些应用程序不使用的参数设置为非活动状态,包括Table Parameter、ParameterList以及JCO.Request对象

5.      添加多行数据到JCO的Table对象中时,使用appendRows(int num_rows)方法代替appendRow()方法,这样可以提高性能

同步问题

为了提高性能,JCO只在访问连接池和Repository对象时采取同步,其他的操作都是异步的,在多线程的环境下,不同线程之间共享对象(比如Table对象)是值得警惕的,并且一个连接对象是不能共享访问的,这样导致发生异常Exception

--转自 北京联动北方科技有限公司

该贴由koei123转至本版2015-2-5 17:26:09



赞(0)    操作        顶端 
koei123
注册用户
等级:大校
经验:4196
发帖:16
精华:0
注册:2011-7-21
状态:离线
发送短消息息给koei123 加好友    发送短消息息给koei123 发消息
发表于: IP:您无权察看 2019-3-2 21:09:18 | [全部帖] [楼主帖] 2  楼


可以试试~



赞(0)    操作        顶端 
总帖数
2
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论