使用 Ruby 加速 IPC

发布于 2025-01-02 18:32:01 字数 385 浏览 2 评论 0原文

我正在尝试在 Ruby 中的同一个 Linux 机器上的 2 个进程之间进行 IPC,并且我需要尽可能优化解决方案。

我开始使用 TCPSocket,但我发现使用 UNIXSocket 可能更快,并且也许不会将数据复制到内核缓冲区。

我一直在阅读 SO 线程,看起来 mmap 可能会很有趣。但对于 mmap,我需要 a) 安装 mmap gem 和 b) 提供锁定,因为多个客户端进程可能会尝试与服务器进程连接(都在同一个盒子上运行)。

我的问题:

  1. 您会推荐哪些其他选择?
  2. 您建议如何使用 ruby​​ mmap 锁定内存?
  3. UNIXSocket 与 mmap 的数字(如果有的话)如何叠加?

I am trying to do IPC between 2 processes on the same Linux box in Ruby, and I need to optimize the solution as far as practicable.

I had begun with a TCPSocket but I see that using UNIXSocket is probably faster, and perhaps does not copy data to kernel buffers.

I have been reading SO threads, and looks like mmap might be interesting to look at. But for mmap I need to a) install mmap gem and b) provide locking since multiple client processes would likely try connect with the server process (both running on same box).

My questions:

  1. What other options would you recommend?
  2. How do you recommend locking the memory with ruby mmap?
  3. How do the numbers, if there's any available, stack up for UNIXSocket versus mmap?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文