0

我们有一个用 C 编写的程序,它使用 RPC 与同一 Linux 服务器上的另一个程序(也用 C 编写)进行通信(在某些生产设置中,第二个 C 程序将在另一台机器上,因此 RPC 而不是 IPC)。

当从其他 C 程序、CRON 或命令行调用时,它按预期工作,并且已经这样做了很多年,所以可以肯定地说它通常可以工作。

从 Groovy 脚本调用的同一个程序失败了,显然是网络问题。

在 C 程序中,svc_register(xprt, prognum, versnum, dispatch, protocol)成功,但随后

  • 请求后在 RPC 服务器上:clnttcp_create失败并显示“连接被拒绝”
  • 在等待回复的 RPC 客户端上:selectonsvc_fdset失败EBADF

Groovy 程序(只是为了完整,这里不多见):

[ "myprogram", "someoption", "someprogram" ].execute()

我们可以尝试查明并解决问题吗?

4

3 回答 3

1

运行程序strace,查看失败的系统调用。

于 2010-08-27T14:30:28.853 回答
1

检查是否myprogram有输出或等待输入。如果您不读取输出或关闭输入,那么它将挂起,导致 RPC 调用超时。创建一个读取inand errofmyprogram和 close的线程out

def p = [ "myprogram", "someoption", "someprogram" ].execute()
p.out.close()
p.consumeProcessOutput()
于 2010-08-27T14:49:40.713 回答
1

显然,从 Groovy 调用基于 RPC 的 C 程序确实有效。

问题可以缩小到“(int)sysconf (_SC_OPEN_MAX)”的问题,它用于确定 svc_fdset(用于从 rpc-requests 获取回复的结构)中的 fds 数量在被使用的情况下会失败通过从 Groovy 调用的 C 程序。

于 2010-08-27T17:39:42.223 回答