如何解决Docker 容器内的 Log4j2 套接字附加程序抛出连接被拒绝
我有一个在 docker 容器上运行的 springboot 应用程序。在我的应用程序中有一个带有套接字附加程序的 log4j.xml 文件。
defmodule Example do
def merge_sort([]),do: []
def merge_sort([_] = list),do: list
def merge_sort(list) when is_list(list) do
len = length(list)
{a,b} = Enum.split(list,div(len,2))
a = merge_sort(a)
b = merge_sort(b)
merge(a,b,[])
end
defp merge([],acc),do: Enum.reverse(acc) ++ b
defp merge(a,[],do: Enum.reverse(acc) ++ a
defp merge([a_head | a_tail] = a,[b_head | b_tail] = b,acc) do
if a_head <= b_head do
merge(a_tail,[a_head | acc])
else
merge(a,b_tail,[b_head | acc])
end
end
end
在我的主机服务器(Ubuntu 服务器)中,它通过 logstash 列出了端口 5100。主机中“netstat -tulpn”命令的输出如下。
<Socket name="Socket" host="172.17.0.1" port="5100">
<JsonLayout compact="true" eventEol="true" />
</Socket>
但是当 springboot 服务器启动时,它的获取连接被拒绝错误。
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:8280 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:5100 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:5001 0.0.0.0:* LISTEN -
我也尝试过“host.docker.internal”,但它不起作用。谁能告诉我这有什么问题吗?
解决方法
正如您从 netstat
输出中看到的,Logstash 仅监听 127.0.0.1:5100
。这意味着它不能从 Docker 内部访问。您必须让它在 172.17.0.1:5100
或 0.0.0.0:5100
上收听。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。