我正在使用mesos和marathon部署一个装有Kibana4的容器。要部署的json是:
{
"id": "/org/products/kibana/webapp",
"instances": 1,
"cpus": 1,
"mem": 768,
"uris": [],
"constraints": [
["hostname", "UNIQUE"]
],
"upgradeStrategy": {
"minimumHealthCapacity": 0.5
},
"healthChecks": [
{
"protocol": "HTTP",
"path": "/",
"portIndex": 0,
"initialDelaySeconds": 600,
"gracePeriodSeconds": 10,
"intervalSeconds": 30,
"timeoutSeconds": 120,
"maxConsecutiveFailures": 10
}
],
"env": {
"ES_HOST":"172.23.10.23",
"ES_PORT":"9200"
},
"container": {
"type": "DOCKER",
"docker": {
"image": "myregistry.local.com:5000/org/kibana:4.0.0",
"network": "BRIDGE",
"portMappings": [
{
"containerPort": 5601,
"hostPort": 0,
"servicePort": 50061,
"protocol": "tcp"
}
]
},
"volumes": [
{
"containerPath": "/etc/localtime",
"hostPath": "/etc/localtime",
"mode": "RO"
}
]
}
}
但是当我发布它时,kibana应用程序永远不会醒来,stderr日志是:
I0227 12:22:44.666357 1149 exec.cpp:132] Version: 0.21.1
I0227 12:22:44.669059 1178 exec.cpp:206] Executor registered on slave 20150225-040104-1124079532-5050-952-S0
/kibana/src/index.js:58
throw error;
^
Error: listen EADDRNOTAVAIL
at errnoException (net.js:905:11)
at Server._listen2 (net.js:1024:19)
at listen (net.js:1065:10)
at net.js:1147:9
at asyncCallback (dns.js:68:16)
at Object.onanswer [as oncomplete] (dns.js:121:9)
之后,我尝试消除端口Map,因为我发现一些引用表明这是端口或网络配置问题。然后我的kibana4web应用程序会很好地唤醒,但我需要配置一个端口Map,以便通过http访问。我不知道为什么马拉松在网络和端口Map配置上有问题。我们会感激你的帮助。
1条答案
按热度按时间goucqfw61#
这是一个令人讨厌的问题,我也遇到了它(在mesos+马拉松上跑Kibana4)。
简而言之:
如果您使用kibana存储库的当前主存储库,则不会发生这种情况—在编写时主存储库中的4.1.0快照中的相关代码已更改。
答案很长:
4.0.0中有这段代码
src/server/index.js
:马拉松用品
HOST
以及POST
默认情况下为环境变量HOST
变量设置为mesos从机的主机名。上面的代码使kibana尝试绑定到mesos从机的ip地址(marathon将其放置在HOST
),它将失败,因为它在docker容器中运行。如果要运行4.0.0,只需将这些行修补到:
目前master中的代码是这样的。