-
Notifications
You must be signed in to change notification settings - Fork 52
/
Copy pathMakefile
95 lines (76 loc) · 3.23 KB
/
Makefile
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
## You can follow the steps below in order to get yourself a local ODC.
## Start by running `setup` then you should have a system that is fully configured
##
## Once running, you can access a Jupyter environment
## at 'http://localhost' with password 'secretpassword'
.PHONY: help setup up down clean
BBOX := 25,20,35,30
help: ## Print this help
@grep -E '^##.*$$' $(MAKEFILE_LIST) | cut -c'4-'
@echo
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-10s\033[0m %s\n", $$1, $$2}'
setup: build up init product index ## Run a full local/development setup
setup-prod: up-prod init product index ## Run a full production setup
up: ## 1. Bring up your Docker environment
docker-compose up -d postgres
docker-compose run checkdb
docker-compose up -d jupyter
init: ## 2. Prepare the database
docker-compose exec -T jupyter datacube -v system init
product: ## 3. Add a product definition for Sentinel-2
docker-compose exec -T jupyter dc-sync-products /conf/products.csv
index: ## 4. Index some data (Change extents with BBOX='<left>,<bottom>,<right>,<top>')
docker-compose exec -T jupyter bash -c \
"stac-to-dc \
--bbox='$(BBOX)' \
--catalog-href='https://earth-search.aws.element84.com/v0/' \
--collections='sentinel-s2-l2a-cogs' \
--datetime='2021-06-01/2021-07-01'"
docker-compose exec -T jupyter bash -c \
"stac-to-dc \
--catalog-href=https://planetarycomputer.microsoft.com/api/stac/v1/ \
--collections='io-lulc'" || true
# doesnt support multipoligon https://github.com/opendatacube/odc-tools/issues/538
docker-compose exec -T jupyter bash -c \
"stac-to-dc \
--catalog-href='https://planetarycomputer.microsoft.com/api/stac/v1/' \
--collections='nasadem' \
--bbox='$(BBOX)'"
down: ## Bring down the system
docker-compose down
build: ## Rebuild the base image
docker-compose pull
docker-compose build
shell: ## Start an interactive shell
docker-compose exec jupyter bash
clean: ## Delete everything
docker-compose down --rmi all -v
logs: ## Show the logs from the stack
docker-compose logs --follow
upload-s3: # Update S3 template (this is owned by Digital Earth Australia)
aws s3 cp cube-in-a-box-cloudformation.yml s3://opendatacube-cube-in-a-box/ --acl public-read
build-image:
docker build --tag opendatacube/cube-in-a-box .
push-image:
docker push opendatacube/cube-in-a-box
up-prod: ## Bring up production version
docker-compose -f docker-compose-prod.yml pull
docker-compose -f docker-compose.yml -f docker-compose-prod.yml up --detach postgres
docker-compose run checkdb
docker-compose -f docker-compose.yml -f docker-compose-prod.yml up --detach --no-build
# This section can be used to deploy onto CloudFormation instead of the 'magic link'
create-infra:
aws cloudformation create-stack \
--region eu-west-1 \
--stack-name odc-test \
--template-body file://cube-in-a-box-cloudformation.yml \
--parameter file://parameters.json \
--tags Key=Name,Value=OpenDataCube \
--capabilities CAPABILITY_NAMED_IAM
update-infra:
aws cloudformation update-stack \
--stack-name eu-west-1 \
--template-body file://cube-in-a-box-cloudformation.yml \
--parameter file://parameters.json \
--tags Key=Name,Value=OpenDataCube \
--capabilities CAPABILITY_NAMED_IAM