forked from TrueCloudLab/frostfs-dev-env
Nikita Zinkevich
ce0223da60
It happens that a volume may not be deleted during `make clean`. For example, if the volume is being used by a container. If this happens, there are no errors printed to stdout. And old volumes may cause errors during subsequent `make up` Signed-off-by: Nikita Zinkevich <n.zinkevich@yadro.com>
182 lines
6.5 KiB
Makefile
182 lines
6.5 KiB
Makefile
#!/usr/bin/make -f
|
|
SHELL = bash
|
|
|
|
# Main environment configuration
|
|
include .env
|
|
|
|
# Optional variables with secrets
|
|
-include .secrets
|
|
|
|
# help target
|
|
include help.mk
|
|
|
|
# update FrostFS global config targets
|
|
include frostfs_config.mk
|
|
|
|
# Targets to get required artifacts and external resources for each service
|
|
include services/*/artifacts.mk
|
|
|
|
# Targets helpful to prepare service environment
|
|
include services/*/prepare.mk
|
|
|
|
# List of services to run
|
|
START_SVCS = $(shell cat .services | grep -v '#')
|
|
START_BASIC = $(shell cat .basic_services | grep -ve '#')
|
|
START_BOOTSTRAP = $(shell cat .bootstrap_services | grep -v '#')
|
|
STOP_SVCS = $(shell tac .services | grep -v '#')
|
|
STOP_BASIC = $(shell tac .basic_services | grep -v '#')
|
|
STOP_BOOTSTRAP = $(shell tac .bootstrap_services | grep -v '#')
|
|
|
|
# Enabled services dirs
|
|
ENABLED_SVCS_DIRS = $(shell echo "${START_BOOTSTRAP} ${START_BASIC} ${START_SVCS}" | sed 's|[^ ]* *|./services/&|g')
|
|
|
|
# Services that require artifacts
|
|
GET_SVCS = $(shell grep -Rl "get.*:" ./services/* | sort -u | grep artifacts.mk | xargs -I {} dirname {} | xargs basename -a)
|
|
|
|
# Services that require pulling images
|
|
PULL_SVCS = $(shell find ${ENABLED_SVCS_DIRS} -type f -name 'docker-compose.yml' | sort -u | xargs -I {} dirname {} | xargs basename -a)
|
|
|
|
# List of hosts available in devenv
|
|
HOSTS_LINES = $(shell grep -Rl IPV4_PREFIX ./services/* | grep .hosts)
|
|
|
|
# Paths to protocol.privnet.yml
|
|
MORPH_CHAIN_PROTOCOL = './services/morph_chain/protocol.privnet.yml'
|
|
|
|
# List of grepped environment variables from *.env
|
|
GREP_DOTENV = $(shell find . -name '*.env' -exec grep -rhv -e '^#' -e '^$$' {} + | sort -u )
|
|
|
|
# Pull all required Docker images
|
|
.PHONY: pull
|
|
pull:
|
|
$(foreach SVC, $(PULL_SVCS), $(shell cd services/$(SVC) && docker-compose pull))
|
|
@:
|
|
|
|
# Get all services artifacts
|
|
.PHONY: get
|
|
get: $(foreach SVC, $(GET_SVCS), get.$(SVC))
|
|
@:
|
|
|
|
# Start environment
|
|
.PHONY: up
|
|
up: up/basic
|
|
@$(foreach SVC, $(START_SVCS), $(shell docker-compose -f services/$(SVC)/docker-compose.yml up -d))
|
|
./vendor/frostfs-adm morph proxy-add-account --config frostfs-adm.yml --account=`docker container exec morph_chain neo-go wallet dump-keys -w /wallets/s3-wallet.json | head -1 | awk '{print $1}'` || die "Couldn't set s3-gw wallet as proxy wallet"
|
|
@echo "Full FrostFS Developer Environment is ready"
|
|
|
|
# Build up FrostFS
|
|
.PHONY: up/basic
|
|
up/basic: up/bootstrap
|
|
@$(foreach SVC, $(START_BASIC), $(shell docker-compose -f services/$(SVC)/docker-compose.yml up -d))
|
|
@./vendor/frostfs-adm -c ./frostfs-adm.yml morph force-new-epoch
|
|
@./vendor/frostfs-adm -c ./frostfs-adm.yml morph set-config SystemDNS=container --force
|
|
@echo "Basic FrostFS Developer Environment is ready"
|
|
|
|
# Start bootstrap services
|
|
.PHONY: up/bootstrap
|
|
up/bootstrap: get vendor/hosts
|
|
@$(foreach SVC, $(START_BOOTSTRAP), $(shell docker-compose -f services/$(SVC)/docker-compose.yml up -d))
|
|
@source ./bin/helper.sh
|
|
@./vendor/frostfs-adm --config frostfs-adm.yml morph init --contracts vendor/contracts
|
|
echo "Set rule chain to policy contract"
|
|
@./vendor/frostfs-adm --config frostfs-adm.yml morph \
|
|
ape add-rule-chain --target-type namespace --target-name "" \
|
|
--rule 'allow Container.* *' --chain-id "allow_container_ops"
|
|
@for f in ./services/storage/wallet*.json; do \
|
|
echo "Transfer GAS to wallet $${f}" \
|
|
&& ./vendor/frostfs-adm -c frostfs-adm.yml morph refill-gas --storage-wallet $${f} --gas 10.0 \
|
|
|| die "Failed to transfer GAS to alphabet wallets"; \
|
|
echo "Register storage wallet $${f} in proxy contract" \
|
|
&& ./vendor/frostfs-adm morph proxy-add-account --config frostfs-adm.yml --account=`docker container exec morph_chain neo-go wallet dump-keys -w /wallets/storage/$${f##*/} | head -1 | awk '{print $1}'` || die "Couldn't set storage allet as proxy wallet"
|
|
done
|
|
@echo "Create frostfsid subject for ./wallets/wallet.json"; \
|
|
if [ -n "$$(./vendor/frostfs-adm -c frostfs-adm.yml morph frostfsid list-subjects --namespace '')" ]; then \
|
|
echo "Subject already exists"; \
|
|
else \
|
|
subj_key=`docker container exec -it morph_chain neo-go wallet dump-keys -w /wallets/wallet.json | tail -1 | tr -d ' \r\n'` \
|
|
&& echo "Subject key: $${subj_key}" \
|
|
&& ./vendor/frostfs-adm -c frostfs-adm.yml morph frostfsid create-subject --namespace "" --subject-key $${subj_key} --subject-name walletsubject \
|
|
|| die "Failed to create subject for the wallet"; \
|
|
fi
|
|
echo "FrostFS sidechain environment is deployed"
|
|
|
|
# Build up certain service
|
|
.PHONY: up/%
|
|
up/%: get vendor/hosts
|
|
@docker-compose -f services/$*/docker-compose.yml up -d
|
|
@echo "Developer Environment for $* service is ready"
|
|
|
|
# Stop environment
|
|
.PHONY: down
|
|
down: down/add down/basic down/bootstrap
|
|
@echo "Full FrostFS Developer Environment is down"
|
|
|
|
.PHONY: down/add
|
|
down/add:
|
|
$(foreach SVC, $(STOP_SVCS), $(shell docker-compose -f services/$(SVC)/docker-compose.yml down))
|
|
|
|
# Stop basic environment
|
|
.PHONY: down/basic
|
|
down/basic:
|
|
$(foreach SVC, $(STOP_BASIC), $(shell docker-compose -f services/$(SVC)/docker-compose.yml down))
|
|
|
|
# Stop bootstrap services
|
|
.PHONY: down/bootstrap
|
|
down/bootstrap:
|
|
$(foreach SVC, $(STOP_BOOTSTRAP), $(shell docker-compose -f services/$(SVC)/docker-compose.yml down))
|
|
|
|
# Stop certain service
|
|
.PHONY: down/%
|
|
down/%:
|
|
@docker-compose -f services/$*/docker-compose.yml down
|
|
|
|
# Generate changes for /etc/hosts
|
|
.PHONY: vendor/hosts
|
|
.ONESHELL:
|
|
vendor/hosts:
|
|
@for file in $(HOSTS_LINES)
|
|
do
|
|
while read h
|
|
do
|
|
echo $${h} | \
|
|
sed 's|IPV4_PREFIX|$(IPV4_PREFIX)|g' | \
|
|
sed 's|LOCAL_DOMAIN|$(LOCAL_DOMAIN)|g'
|
|
done < $${file};
|
|
done > $@
|
|
|
|
# Generate and display changes for /etc/hosts
|
|
.PHONY: hosts
|
|
hosts: vendor/hosts
|
|
@cat vendor/hosts
|
|
|
|
# Clean-up the environment
|
|
.PHONY: clean
|
|
.ONESHELL:
|
|
clean:
|
|
@rm -rf vendor/* services/storage/s04tls.*
|
|
@> .int_test.env
|
|
@for svc in $(PULL_SVCS)
|
|
do
|
|
vols=`docker-compose -f services/$${svc}/docker-compose.yml config --volumes`
|
|
if [[ ! -z "$${vols}" ]]; then
|
|
for vol in $${vols}; do
|
|
docker volume rm -f "$${svc}_$${vol}"
|
|
done
|
|
fi
|
|
done
|
|
|
|
# Generate environment
|
|
.PHONY: env
|
|
env:
|
|
@$(foreach envvar,$(GREP_DOTENV),echo $(envvar);)
|
|
@echo MORPH_BLOCK_TIME=$(shell grep 'TimePerBlock' $(MORPH_CHAIN_PROTOCOL) | awk '{print $$2}')s
|
|
@echo MORPH_MAGIC=$(shell grep 'Magic' $(MORPH_CHAIN_PROTOCOL) | awk '{print $$2}')
|
|
|
|
# Restart storage nodes with clean volumes
|
|
.PHONY: restart.storage-clean
|
|
restart.storage-clean:
|
|
@docker-compose -f ./services/storage/docker-compose.yml down
|
|
@$(foreach vol, \
|
|
$(shell docker-compose -f services/storage/docker-compose.yml config --volumes),\
|
|
docker volume rm storage_$(vol);)
|
|
@docker-compose -f ./services/storage/docker-compose.yml up -d
|
|
|