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

标签 java

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

相关文章:

java - 具有泛型和 O(1) 操作的 Java 中的 LRU 缓存

java - 如何在数组中搜索并从方法返回?

Java : Scroll Over JScrollPane

java - Java中无论点击Jlist多少次,如何从Jlist中获取选定的值

java - Web 应用程序的配置文件 - 加载一次并存储在哪里?

java - Ehcache - 使用 List<Integer> 作为缓存值

java - 错误 : "Cannot invoke String() on the primitive type float " on quadratic formula?

java - Java 中的 Miller-Rabin 素数测试

java - 在 web-inf\lib 中找不到适合 jdbc :db2 with db2jcc4. jar 的驱动程序

java - 如何使用java将YYYYMMDD转换为YYYY-MM DD格式