Skip to content

Instantly share code, notes, and snippets.

@neunhoef
Created December 7, 2016 11:08
Show Gist options
  • Save neunhoef/1620c6c50e84a12be2b476bed419c644 to your computer and use it in GitHub Desktop.
Save neunhoef/1620c6c50e84a12be2b476bed419c644 to your computer and use it in GitHub Desktop.
Docker compose file to start a local arangodb cluster
version: '2'
services:
agency:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.endpoint tcp://0.0.0.0:5001 --server.authentication false --agency.activate true --agency.size 1 --agency.supervision true --database.directory /var/lib/arangodb3/agency1
coordinator:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.authentication=false --server.endpoint tcp://0.0.0.0:8529 --cluster.my-address tcp://coordinator:8529 --cluster.my-local-info coord1 --cluster.my-role COORDINATOR --cluster.agency-endpoint tcp://agency:5001 --database.directory /var/lib/arangodb3/coordinator
ports: ['8000:8529']
depends_on:
- agency
coordinator2:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.authentication=false --server.endpoint tcp://0.0.0.0:8529 --cluster.my-address tcp://coordinator2:8529 --cluster.my-local-info coord2 --cluster.my-role COORDINATOR --cluster.agency-endpoint tcp://agency:5001 --database.directory /var/lib/arangodb3/coordinator
ports: ['8001:8529']
depends_on:
- agency
db1:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.authentication=false --server.endpoint tcp://0.0.0.0:8529 --cluster.my-address tcp://db1:8529 --cluster.my-local-info db1 --cluster.my-role PRIMARY --cluster.agency-endpoint tcp://agency:5001 --database.directory /var/lib/arangodb3/primary1
depends_on:
- agency
db2:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.authentication=false --server.endpoint tcp://0.0.0.0:8529 --cluster.my-address tcp://db2:8529 --cluster.my-local-info db2 --cluster.my-role PRIMARY --cluster.agency-endpoint tcp://agency:5001 --database.directory /var/lib/arangodb3/primary1
depends_on:
- agency
db3:
image: arangodb/arangodb
environment:
- ARANGO_NO_AUTH=1
command: arangod --server.authentication=false --server.endpoint tcp://0.0.0.0:8529 --cluster.my-address tcp://db3:8529 --cluster.my-local-info db3 --cluster.my-role PRIMARY --cluster.agency-endpoint tcp://agency:5001 --database.directory /var/lib/arangodb3/primary1
depends_on:
- agency
@ninformations
Copy link

@mikestaub yes you can .. arangodb coordinator is accessible from outside. you can access anyone ports exposed by coordinator..
localhost:8000 or localhost:8001 will do your job.

@suewonjp
Copy link

Excellent post. But it won't work with Docker swarm.

Basically, it misses --agency.my-address option for the agency service.

https://groups.google.com/forum/?hl=de#!topic/arangodb/iQ-ualcOn2A

With it fixed, it will work with docker swarm. Please, update this excellent yml file so it can be more useful. Thanks.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment