我编写了一个 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/