2017-10-18 82 views
0

我有一个正在运行的Mesos/Marathon集群,但正在运行的实例的IP不会传播到Marathon-UI或traefik代理。运行实例的IP不会传播

我mesos设置:

ExecStart=/bin/bash -c "/usr/sbin/mesos-slave \ 
      --hostname=$(/usr/bin/hostname) \ 
      --work_dir=/var/lib/mesos \ 
      --master=zk://xxx.net:2181,yyy:2181,zzz:2181/mesos \ 
      --log_dir=/var/log/mesos \ 
      --executor_registration_timeout=10mins \ 
      --containerizers=docker,mesos \ 
      --docker=$(which docker) \ 
      --ip=$(ifconfig eth0 | grep -oP 'inet \K\S+')" 

我treafik的conf:

logLevel = "INFO" 
[web] 
address = ":8088" 
[marathon] 
endpoint = "http://xxx:8080" 
watch = true 
domain = "xxx" 
exposedByDefault = true 
groupsAsSubDomains = true 
forceTaskHostname = true 

[accessLog] 

enter image description here enter image description here

UPDATE: 应用程序定义是:

{ 
    "id": "/web", 
    "cmd": null, 
    "cpus": 1, 
    "mem": 64, 
    "disk": 0, 
    "instances": 1, 
    "acceptedResourceRoles": [ 
    "*" 
    ], 
    "container": { 
    "type": "DOCKER", 
    "volumes": [], 
    "docker": { 
     "image": "ldaume/caddy", 
     "network": "BRIDGE", 
     "portMappings": [ 
     { 
      "containerPort": 2015, 
      "hostPort": 0, 
      "servicePort": 10001, 
      "protocol": "tcp", 
      "labels": {} 
     } 
     ], 
     "privileged": false, 
     "parameters": [], 
     "forcePullImage": false 
    } 
    }, 
    "portDefinitions": [ 
    { 
     "port": 10001, 
     "protocol": "tcp", 
     "labels": {} 
    } 
    ] 
} 

如果我将Marathon DNS与给定端口一起使用,则可以访问该应用程序。

+0

您能否指定您正在使用的Marathon版本,并添加已清理的应用程序定义?马拉松队的Ivan说:“如果是Marathon 1.5.x,那么答案可能很简单,因为Marathon已经过时了,并且有一些突破了1.5的网络相关变化,或许这同样适用于traefik”。尽管考虑下面的答案,但对于traefik来说可能并不相同。 –

+0

因@JudithMalnick。我在使用Marathon 1.4.8(在尝试1.5.1之前)使用Mesos 1.4在Debian伸展(9)和traefik 1.4 – Lenny

+0

甜,谢谢!你可以添加你的应用程序或pod定义吗? –

回答

0

我和你有相同的设置,我有我的报告正确。我正在使用1.4 traefik。 Traefik配置很简单:

################################################################ 
# Global configuration 
################################################################ 

defaultEntryPoints = ["http"] 


################################################################ 
# Web configuration backend 
################################################################ 

[web] 
    address = ":8081" 

################################################################ 
# Marathon configuration backend 
################################################################ 


[marathon] 
    endpoint = "http://172.31.xx.xx:8080" 

    domain = "marathon.localhost" 

    watch = true 

...... 正在使用Docker容器的AWS设置,其中端点是内部IP VPC,而不是外部的AWS IP。