logstash 尝试连接到映射的 ipv6 地址上的 redis 服务器

logstash 尝试连接到映射的 ipv6 地址上的 redis 服务器

我刚开始玩日志存储,我在让日志传送器进程将事件发送到另一台主机上的 redis 服务器时遇到了问题。

output我的 logstash 配置文件的节如下

输出 {
  redis { 主机 => “11.22.33.44” 数据类型 => “列表” 键 => “logstash” }
}

但是,当我运行 logstash 进程时,我收到包含以下内容的错误消息:

:exception=>#<SocketError:网络不可达>

稍微一strace查就发现它在这里失败了:

connect(13, {sa_family=AF_INET6, sin6_port=htons(6379), inet_pton(AF_INET6, "::ffff:11.22.33.44", &sin6_addr) = -1 ENETUNREACH (网络不可达)

即尝试连接到 ipv6 映射的 ipv4 地址上的 redis 主机。该主机没有本机 ipv6 地址,因此连接失败。

我怎样才能让进程使用AF_INET而不是AF_INET6,或者以某种方式配置我的主机来解决这个问题?

如果相关的话,我的 Java 版本是

Java 版本“1.6.0_18”
OpenJDK 运行时环境(IcedTea6 1.8.13)(6b18-1.8.13-0+squeeze2)
OpenJDK 64 位服务器 VM(版本 14.0-b16,混合模式)

答案1

这是由于这个错误:该sysctl设置net.ipv6.bindv6only=1会破坏 Debian squeeze(可能还有其他平台)中的 Java 网络。

该设置似乎只对想要区分 ipv6 和 ipv4 连接的人有用。我不太在意这个,所以我做了

$ sudo sysctl -w net.ipv6.bindv6only=0

启动了 logstash 代理,并且成功了!

logstash 的创建者后来好心地告诉我,你也可以添加-Djava.net.preferIPv4Stack=true到命令行中。

相关内容