| version: '2' |
| services: |
| # |
| # Single-node zookeeper service |
| # |
| zookeeper: |
| image: wurstmeister/zookeeper |
| ports: |
| - 2181 |
| environment: |
| SERVICE_2181_NAME: "zookeeper" |
| # |
| # Single-node kafka service |
| # |
| kafka: |
| image: wurstmeister/kafka |
| ports: |
| - 9092 |
| environment: |
| KAFKA_ADVERTISED_HOST_NAME: ${DOCKER_HOST_IP} |
| KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181 |
| KAFKA_AUTO_CREATE_TOPICS_ENABLE: 'true' |
| KAFKA_HEAP_OPTS: "-Xmx256M -Xms128M" |
| SERVICE_9092_NAME: "kafka" |
| depends_on: |
| - consul |
| volumes: |
| - /var/run/docker.sock:/var/run/docker.sock |
| # |
| # Single-node consul agent |
| # |
| consul: |
| image: consul:latest |
| command: agent -server -bootstrap -client 0.0.0.0 -ui |
| ports: |
| - "8300:8300" |
| - "8400:8400" |
| - "8500:8500" |
| - "8600:8600/udp" |
| environment: |
| #SERVICE_53_IGNORE: "yes" |
| SERVICE_8300_IGNORE: "yes" |
| SERVICE_8400_IGNORE: "yes" |
| SERVICE_8500_NAME: "consul-rest" |
| # |
| # Registrator |
| # |
| registrator: |
| image: gliderlabs/registrator:latest |
| command: [ |
| "-ip=${DOCKER_HOST_IP}", |
| "-retry-attempts", "100", |
| # "-internal", |
| "consul://consul:8500" |
| ] |
| links: |
| - consul |
| volumes: |
| - "/var/run/docker.sock:/tmp/docker.sock" |
| # |
| # Fluentd log server |
| # |
| fluentd: |
| image: fluent/fluentd |
| ports: |
| - "24224:24224" |
| volumes: |
| - "/tmp/fluentd:/fluentd/log" |
| environment: |
| SERVICE_24224_NAME: "fluentd-intake" |
| |
| # |
| # Podder service instance |
| # |
| podder: |
| image: cord/podder |
| volumes: |
| - "/var/run/docker.sock:/tmp/docker.sock" |
| restart: unless-stopped |
| |
| # |
| # Graphite-Grafana-statsd service instance |
| # (demo place-holder for external KPI system) |
| # |
| grafana: |
| image: kamon/grafana_graphite |
| ports: |
| - "8882:80" |
| - "2003:2003" |
| - "2004:2004" |
| - "8126:8126" |
| - "8125:8125/udp" |
| environment: |
| SERVICE_80_NAME: "grafana-web-ui" |
| SERVICE_2003_NAME: "carbon-plain-text-intake" |
| SERVICE_2004_NAME: "carbon-pickle-intake" |
| SERVICE_8126_NAME: "statsd-tcp-intake" |
| SERVICE_8125_NAME: "statsd-udp-intake" |
| |
| # |
| # Shovel (Kafka-graphite-gateway) |
| # |
| shovel: |
| image: cord/shovel |
| command: [ |
| "/shovel/shovel/main.py", |
| "--kafka=@kafka", |
| "--consul=${DOCKER_HOST_IP}:8500", |
| "--topic=voltha.kpis", |
| "--host=${DOCKER_HOST_IP}" |
| ] |
| depends_on: |
| - consul |
| - kafka |
| - grafana |
| |
| # |
| # Voltha server instance(s) |
| # |
| voltha: |
| image: cord/voltha |
| command: [ |
| "/voltha/voltha/main.py", |
| "-v", |
| "--consul=${DOCKER_HOST_IP}:8500", |
| "--fluentd=fluentd:24224", |
| "--rest-port=8880", |
| "--grpc-port=50555", |
| "--kafka=@kafka", |
| "--instance-id-is-container-name", |
| "-v" |
| ] |
| ports: |
| - 8880 |
| - 50555 |
| - 18880 |
| depends_on: |
| - consul |
| - podder |
| links: |
| - consul |
| - fluentd |
| environment: |
| SERVICE_8880_NAME: "voltha-health" |
| SERVICE_8880_CHECK_HTTP: "/health" |
| SERVICE_8880_CHECK_INTERVAL: "5s" |
| SERVICE_8880_CHECK_TIMEOUT: "1s" |
| SERVICE_50555_NAME: "voltha-grpc" |
| SERVICE_18880_NAME: "voltha-sim-rest" |
| volumes: |
| - "/var/run/docker.sock:/tmp/docker.sock" |
| networks: |
| - default |
| - ponmgmt |
| |
| networks: |
| default: |
| driver: bridge |
| ponmgmt: |
| driver: bridge |