0

我有一个使用 JCo 3 构建的基于 java 的 idoc 侦听服务器。当我启动它并从 sap 系统发送一个 Idoc 时,它给了我一个异常。

com.sap.conn.idoc.IDocRuntimeException: Failed to resolve repository reference @MYDESTINATION
    at com.sap.conn.idoc.jco.rt.DefaultJCoIDocServer$IDocRepositoryMapBox$IDocRepositoryReference.getRepository(DefaultJCoIDocServer.java:245)
    at com.sap.conn.idoc.jco.rt.DefaultJCoIDocServer$IDocRepositoryMapBox.getRepository(DefaultJCoIDocServer.java:397)
    at com.sap.conn.idoc.jco.rt.DefaultJCoIDocServer.getIDocRepository(DefaultJCoIDocServer.java:128)
    at com.sap.conn.idoc.jco.rt.DefaultJCoIDocServerWorker$IDocDispatcher.createIDocDocumentListArray(DefaultJCoIDocServerWorker.java:445)
    at com.sap.conn.idoc.jco.rt.DefaultJCoIDocServerWorker$IDocDispatcher.handleRequest(DefaultJCoIDocServerWorker.java:209)
    at com.sap.conn.jco.rt.DefaultServerWorker.dispatchRequest(DefaultServerWorker.java:148)
    at com.sap.conn.jco.rt.MiddlewareJavaRfc$JavaRfcServer.dispatchRequest(MiddlewareJavaRfc.java:3680)
    at com.sap.conn.jco.rt.MiddlewareJavaRfc$JavaRfcServer.executePlayback(MiddlewareJavaRfc.java:3158)
    at com.sap.conn.jco.rt.MiddlewareJavaRfc$JavaRfcServer.playbackTRfc(MiddlewareJavaRfc.java:2981)
    at com.sap.conn.jco.rt.MiddlewareJavaRfc$JavaRfcServer.handletRfcRequest(MiddlewareJavaRfc.java:2875)
    at com.sap.conn.jco.rt.MiddlewareJavaRfc$JavaRfcServer.listen(MiddlewareJavaRfc.java:2674)
    at com.sap.conn.jco.rt.DefaultServerWorker.dispatch(DefaultServerWorker.java:275)
    at com.sap.conn.jco.rt.DefaultServerWorker.loop(DefaultServerWorker.java:356)
    at com.sap.conn.jco.rt.DefaultServerWorker.run(DefaultServerWorker.java:232)
    at java.lang.Thread.run(Thread.java:745)
Caused by: com.sap.conn.jco.JCoException: (102) JCO_ERROR_COMMUNICATION: Connect to message server host failed
Connection parameters: TYPE=B DEST=MYDESTINATION MSHOST=192.168.56.101 R3NAME=NSP GROUP=PUBLIC PCS=1

ERROR       partner '192.168.56.101:sapmsNSP' not reached
TIME        Thu Jan 12 16:19:21 2017
RELEASE     721
COMPONENT   NI (network interface)
VERSION     40
RC          -10
MODULE      nixxi.cpp
LINE        3283
DETAIL      NiPConnect2: 192.168.56.101:3600
SYSTEM CALL connect
ERRNO       61
ERRNO TEXT  Connection refused
COUNTER     1

正如它所说,我认为这是由于消息服务器不可用并登录到 sap 机器并使用 netstat 检查打开的端口。

端口 3600 未在侦听,但报告端口 7200 已被 msg_server.exe 打开。我已将我的 jco 服务器端机器的 /etc/services 文件设置为,sapmsNSP 3600/tcp但即使我将其更改为 7200,它也会给我异常说内部错误

4

1 回答 1

1

错误消息表明主机 192.168.56.101 上没有正在运行的进程侦听端口 3600。这意味着 SAP 消息服务器进程正在侦听不同的端口,或者根本没有运行。

如果您可以使用 SAP GUI 对 ABAP 系统 NSP 进行组登录,则应该正确配置您的服务文件。顺便说一句,SAP 消息服务器进程在 Windows 上通常被命名为 msg_server.exe - 而不是 message_server.exe。如果您更改了服务文件,您至少应该在显示修改后的端口号的 DETAIL 错误消息部分收到不同的错误消息。否则您无法更改服务文件(未保存?最后一行后没有回车?)或者您在更改服务文件后没有重新启动 JCo 服务器程序。

于 2017-01-12T13:57:17.663 回答