5

我用 Java 构建了一个自定义消息服务器,它接收消息流并将每条消息传递给其客户端(1:1,如果未连接,则丢弃 msg - 非常简单)。我在 Win7x64 和 Java 7 上运行 Tomcat 7,并且正在使用 NIO 连接器(实现了 Comet servlet)。它工作得很好,但我现在正在研究扩展这个野兽,目前看到为每个连接的客户端分配了大约 85kb 的 RAM。10.000 个客户端 @ 小于 900MB 并线性扩展。(除了保持连接之外,我没有做任何其他事情)我认为这很重要,所以我想知道是否有一些调整可以使 Tomcat 或 Java 使用它们的 NIO impl 节省更多内存。到目前为止,我尝试的所有 Tomcat 设置都没有影响到这一点。

有没有人有经验如何将 Java 或 Tomcat 放在有关套接字连接的内存饮食中?

更新:通过修剪套接字缓冲区和其他一些 tomcat 内部,我现在低于 70kb/连接。不确定这现在如何影响吞吐量。我也在 32bit / 64bit linux 上尝试过,结果相同。

4

1 回答 1

2

经过相当多的研究和玩弄后,我得出的结论是,Tomcat 根本不可能用合理的内存量来处理大量并发连接。(顺便说一句,我仍然很高兴在这里被证明是错误的)

然而,有一个救星:

网络:http ://www.jboss.org/netty/downloads

它是一个 Java IO 框架,建立在 Java 的新 NIO 架构之上,看起来设计和编写都非常好。您可以将一些轻量级模块堆叠在一起并创建一个迷你网络服务器,或者简单地自己以异步方式处理 TCP 连接。

我在 EC2 上运行了一个负载测试,并在只有 1.5GB 的 RAM 时达到了惊人的 700 万个连接!(就像 tomcat 测试一样,我只存储了连接,所以一个真正的应用程序当然会消耗更多的内存,但是 200 字节/连接的“开销”不算什么!)它只是停在那里,因为我限制了 Java VM到 1.5GB,我相信 C10M 测试很容易做到。

向 Netty 和 Java VM 家伙们致敬!我印象深刻。

于 2012-04-22T18:16:09.960 回答