-
Notifications
You must be signed in to change notification settings - Fork 350
/
Copy pathdocker-compose.yml
80 lines (78 loc) · 3 KB
/
docker-compose.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# This docker-compose is intended to help you quick-start or develop cartography.
# It is also a good starting point for your own customizations.
# If you want to modify this and contribute your change upstream, please file a GitHub issue first. It's hard to make
# this so that it will support as many users as possible, so we've tried to make this with a minimum set of
# functionality that you can extend on your own.
services:
neo4j:
image: neo4j:4.4-community
restart: unless-stopped
ports:
- 7474:7474
- 7687:7687
volumes:
- ./.compose/neo4j/conf:/conf
- ./.compose/neo4j/data:/data
- ./.compose/neo4j/import:/import
- ./.compose/neo4j/logs:/logs
- ./.compose/neo4j/plugins:/plugins
environment:
# Raise memory limits:
- NEO4J_dbms_memory_pagecache_size=1G
- NEO4J_dbms.memory.heap.initial_size=1G
- NEO4J_dbms_memory_heap_max__size=1G
# Auth:
- NEO4J_AUTH=none
# Add APOC and GDS:
- apoc.export.file.enabled=true
- apoc.import.file.enabled=true
- apoc.import.file.use_neo4j_config=true
- NEO4JLABS_PLUGINS=["graph-data-science", "apoc"]
- NEO4J_dbms_security_procedures_allowlist=gds.*, apoc.*
- NEO4J_dbms_security_procedures_unrestricted=gds.*, apoc.*
# Networking:
- dbms.connector.bolt.listen_address=0.0.0.0:7687
healthcheck:
test: ["CMD", "wget", "--no-verbose", "http://localhost:7474"]
interval: 10s
timeout: 10s
retries: 10
# Runs the standard cartography image available at ghcr.io.
cartography:
image: ghcr.io/cartography-cncf/cartography:latest
platform: linux/x86_64
# EXAMPLE: Our ENTRYPOINT is cartography, running specific command to sync AWS
# command: ["-v", "--neo4j-uri=bolt://neo4j:7687", "--aws-sync-all-profiles"]
init: true
restart: on-failure
depends_on:
- neo4j
volumes:
# Provide AWS creds to the container
# Add other volumes here to support other data providers.
- ~/.aws:/var/cartography/.aws/
environment:
# Point to the neo4j service defined in this docker-compose file.
- NEO4J_URL=bolt://cartography-neo4j-1:7687
# Intended to run local automated tests, custom sync scripts, and local changes.
cartography-dev:
# See dev instructions: we assume that you have built this with
# `docker build -t cartography-cncf/cartography-dev -f dev.Dockerfile ./`
image: cartography-cncf/cartography-dev
init: true
restart: on-failure
depends_on:
- neo4j
volumes:
# Provide AWS creds to the container
- ~/.aws:/var/cartography/.aws/
# For pre-commit to work
- .:/var/cartography
- ./.cache/pre-commit:/var/cartography/.cache/pre-commit
# for git, for precommit
- ./.git:/var/cartography/.git
environment:
# Point to the neo4j service defined in this docker-compose file.
- NEO4J_URL=bolt://cartography-neo4j-1:7687
# this is actually needed
- PRE_COMMIT_HOME=/var/cartography/.cache