gpt4 book ai didi

sockets - 如何控制 Scala 远程参与者的 TCP_NODELAY 设置?

转载 作者:可可西里 更新时间:2023-11-01 02:40:25 25 4
gpt4 key购买 nike

我正在使用 Scala 的远程参与者,但往返时间(即使是一条微不足道的消息)是 80 毫秒,大概是由于底层套接字没有禁用 TCP/IP Nagle 算法(也称为 TCP_NODELAY),或者至少这是一些具有 Java RMI 经验的人告诉我的。

我在客户端中为获取到远程参与者的链接所做的一切就是

val server=select(Node("127.0.0.1",12111),'server)

有什么方法可以获取底层套接字并对其调用 java.net.Socket.setTcpNoDelay() 吗?

最佳答案

如果您需要在不修改 Scala 源代码的情况下在底层 Socket 上调用 setTcpNoDelay(),有两种方法可以实现。

  1. 实现您自己的 SocketImplFactory:此解决方案很糟糕,因为您需要实现您自己的 SocketImpl,这并不简单,而且您不能只包装现有的 SocketImpl,因为它不是公共(public) API。我在这里只能说,这首先归咎于设计 SocketImplFactory 的人。

  2. 使用AOP

顺便说一句,我认为解决这个问题最好的方法是修改Scala remote actor代码并提交补丁。

关于sockets - 如何控制 Scala 远程参与者的 TCP_NODELAY 设置?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1540369/

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