我刚开始玩日志存储,我在让日志传送器进程将事件发送到另一台主机上的 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
到命令行中。