gpt4 book ai didi

java - 我如何限制Java中的带宽?

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:03:48 31 4
gpt4 key购买 nike

我编写了一个 Java 调度程序,每小时使用:

new SAXBuilder().build(new URL(xxx));

HttpConnection.connect(new URL(xxx)); // jsoup library code

获取一个大的 XML/HTML 文件。

我的服务器最大带宽限制是 2Mbits。

运行此 Java 计划代码时,我使用了超过 2Mbits 的带宽。 ( check it out )

所以每次用户访问我的服务器时都太慢了。

如何限制我的 Java 计划使用较低的带宽?(例如 500Kbits)

我正在使用 Ubuntu 服务器。

最佳答案

没有优雅的方法可以做到这一点。

一种简单但不优雅的方法是编写一个 Java 流包装器来限制从包装流中读取字节的速率。例如,如果您想限制为每秒 1000 个字节,则可以按如下方式实现 int read() 方法:

Stream in;
long timestamp = System.currentTimeInMillis();
int counter = 0;
int INTERVAL = 1000; // one second
int LIMIT = 1000; // bytes per INTERVAL

...

/**
* Read one byte with rate limiting
*/
@Override
public int read() {
if (counter > LIMIT) {
long now = System.currentTimeInMillis();
if (timestamp + INTERVAL >= now) {
Thread.sleep(timestamp + INTERVAL - now);
}
timestamp = now;
counter = 0;
}
int res = in.read();
if (res >= 0) {
counter++;
}
return res;
}

值得注意的是,像这样的节流率可能会产生负面影响,也可能会产生正面影响。消极的一面:

  • 它在服务器端占用资源的时间更长。在这种情况下,我们讨论的是处理下载的 Java 线程,内核空间中的内存用于缓冲接收到的网络数据包,直到应用程序读取它们。

  • 它还可能导致更多 网络流量。问题是这种节流会破坏数据包的顺畅流动。服务器只会缓冲相对较少数量的数据包,当超过该数量时,它必须告诉客户端暂时停止。这需要额外的信令包 (ACK),并且在此过程中可能会丢弃数据包。最终,这些数据包将需要重新传输。

关于java - 我如何限制Java中的带宽?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3947621/

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