gpt4 book ai didi

linux - 为什么 RPC 调用在从 Linux 上的 Groovy 调用的 C 程序中失败?

转载 作者:太空宇宙 更新时间:2023-11-04 09:08:51 25 4
gpt4 key购买 nike

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

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

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

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

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

Groovy 程序(只是为了完整性,这里没有太多可看的):

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

我们可以尝试查明和解决问题的哪些方面?

最佳答案

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

问题可以缩小到“(int)sysconf (_SC_OPEN_MAX)”的问题,它用于确定 svc_fdset(用于从 rpc-requests 获得回复的结构)中的 fds 数量,以防万一被从 Groovy 调用的 C 程序使用。

关于linux - 为什么 RPC 调用在从 Linux 上的 Groovy 调用的 C 程序中失败?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3585091/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com