首页 > 解决方案 > Java net URL 无法正常工作,弄乱了 HTTP

问题描述

我将 Kafka 与 Avro 和 Schema Registry 一起使用。在向 Kafka 发布消息时,avro 序列化程序使用 java.net.URL 并执行 POST 以在模式注册表中注册 Avro 模式。当模式很大时,HTTP 请求会中断,套接字内容就会变得混乱。我不确定这是否与Mac有关。

在一个终端中,我使用了 NC 并执行了:

nc -lv 8102

在我的 ide (IntelliJ) 和命令行上,我执行了:

public class Main {
    public static void main(String[] args) throws Exception {
        var url = new URL("http://localhost:8102/subjects/local.something-something/versions");
        var connection = (HttpURLConnection) url.openConnection();
        connection.setRequestMethod("POST");
        connection.setDoInput(true);
        connection.setRequestProperty("Content-Type", "application/vnd.schemaregistry.v1+json");
        connection.setRequestProperty("Cache-Control", "no-cache");
        connection.setRequestProperty("Pragma", "no-cache");
        connection.setRequestProperty("User-Agent", "Java/11.0.11");
        connection.setRequestProperty("Accept", "text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2");
        connection.setRequestProperty("Content-Length", "67193");

        connection.setUseCaches(false);
        connection.setDoOutput(true);
        var os = connection.getOutputStream();
        var body = new byte[67193];
        Arrays.fill(body, (byte) 'a');
        os.write(body);
        os.flush();
        os.close();
        connection.getResponseCode();
    }
}

并且NC的输出有(我删除了一些'a'以便于可视化):

aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaPOST /subjects/local.something-something/versions HTTP/1.1
Content-Type: application/vnd.schemaregistry.v1+json
Cache-Control: no-cache
Pragma: no-cache
User-Agent: Java/11.0.11
Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2
Host: localhost:8102
Connection: keep-alive
Content-Length: 67193

aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa

这是无效的,并且架构注册表返回 400

我正在使用Java 11采用 OpenJdk,也尝试过使用oracle JDK 和Correto,但没有成功。

有任何想法吗?

标签: javahttpapache-kafkaconfluent-schema-registry

解决方案


我找到了一个快速的解决方法,我将 jvm 设置为使用 ipv4,问题就消失了。

在 Gradle 上看起来像:

    jvmArgs '-Djava.net.preferIPv4Stack=true'

推荐阅读