Giter Site home page Giter Site logo

Comments (6)

solidsnack avatar solidsnack commented on July 21, 2024

The random port Marathon allocates is actually for use by HAProxy...it's a little hard to understand at first. Basically, there is a "Marathon port" and a "Mesos port". Deimos understands and works with the Mesos port. Deimos never sees the "Marathon port", which you are supposed to bridge to with HAProxy.

We're not really what to do with this one going forward. Note that the environment variables PORT0 (PORT1, &c) contain the Mesos ports, not the Marathon ports.

from deimos.

alexandernilsson avatar alexandernilsson commented on July 21, 2024

I did a small hack to deimos/docker.py to read out the --exposed option and use that for the inner port in deimos.py run().

Replace line 22 with this: https://gist.github.com/alexandernilsson/1e4ea85099196b2787ec

It obviously only works with a single port. Submitting it as a gist instead of PR because I honestly don't like the approach myself.

from deimos.

solidsnack avatar solidsnack commented on July 21, 2024

What does the Marathon task look like that uses the --expose option?

from deimos.

solidsnack avatar solidsnack commented on July 21, 2024

@MikeMichel It would be great to see an example of a container spec and a Marathon request, as well as the desired port mappings.

  • If you can, the Dockerfile or the result of

    sudo docker inspect --format \
         '{{.ContainerConfig.PortSpecs}}{{"\n"}}{{.ContainerConfig.ExposedPorts}}' \
         <image-name>
    

    would be great information to have.

  • The Marathon JSON would be helpful, too.

from deimos.

MikeMichel avatar MikeMichel commented on July 21, 2024

Seems i need to dive more into the marathon/mesos port thing but in the end i got what i needed by using app.listen(process.env.PORT) in the nodejs app i tried to deploy and let marathon do all the portmapping. Now i have working links to the app in the task tab of the marathon webgui and the produced haproxy output works too

listen fibu_15471
  bind 127.0.0.1:15471
  mode http
  option tcplog
  option httpchk GET /
  balance leastconn
  server fibu-3 MesosSlave01.fritz.box:31076 check
  server fibu-2 MesosSlave02:31564 check
  server fibu-1 MesosSlave01.fritz.box:31175 check

Right now i have no access to the environment for further testing. will continue in 2 weeks when im back from vacation.

Mike

from deimos.

ssorallen avatar ssorallen commented on July 21, 2024

It sounds like @solidsnack was able to help you solve this issue, so I'm going to close it. Feel free to comment again and reopen if you still have questions, @MikeMichel.

from deimos.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.