#4 Add pvc backup/restore Dockerfile
This commit is contained in:
		
							parent
							
								
									bfbe13fa80
								
							
						
					
					
						commit
						66e9512c80
					
				|  | @ -0,0 +1,12 @@ | ||||||
|  | FROM alpine:3.9 | ||||||
|  | 
 | ||||||
|  | RUN set -x && \ | ||||||
|  |     addgroup -S user -g 1000 && \ | ||||||
|  |     adduser -S user -G user && \ | ||||||
|  |     apk add --no-cache bash | ||||||
|  | WORKDIR /home/user/bin | ||||||
|  | COPY bin . | ||||||
|  | RUN chmod +x *.sh | ||||||
|  | USER user | ||||||
|  | 
 | ||||||
|  | CMD exec /bin/sh -c "trap : TERM INT; (while true; do sleep 1000; done) & wait" | ||||||
|  | @ -0,0 +1,171 @@ | ||||||
|  | # Set POSIX sh for maximum interoperability
 | ||||||
|  | SHELL := /bin/sh | ||||||
|  | PATH  := $(GOPATH)/bin:$(PATH) | ||||||
|  | 
 | ||||||
|  | # Import config
 | ||||||
|  | # You can change the default config with `make config="config_special.env" build`
 | ||||||
|  | config ?= config.env | ||||||
|  | include $(config) | ||||||
|  | 
 | ||||||
|  | # Set an output prefix, which is the local directory if not specified
 | ||||||
|  | PREFIX?=$(shell pwd) | ||||||
|  | 
 | ||||||
|  | VERSION := $(shell cat VERSION.txt) | ||||||
|  | GITCOMMIT := $(shell git rev-parse --short HEAD) | ||||||
|  | GITBRANCH := $(shell git rev-parse --abbrev-ref HEAD) | ||||||
|  | GITUNTRACKEDCHANGES := $(shell git status --porcelain --untracked-files=no) | ||||||
|  | GITIGNOREDBUTTRACKEDCHANGES := $(shell git ls-files -i --exclude-standard) | ||||||
|  | ifneq ($(GITUNTRACKEDCHANGES),) | ||||||
|  |     GITCOMMIT := $(GITCOMMIT)-dirty | ||||||
|  | endif | ||||||
|  | ifneq ($(GITIGNOREDBUTTRACKEDCHANGES),) | ||||||
|  |     GITCOMMIT := $(GITCOMMIT)-dirty | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | VERSION_TAG := $(VERSION) | ||||||
|  | LATEST_TAG := latest | ||||||
|  | BUILD_TAG := $(GITBRANCH)-$(GITCOMMIT) | ||||||
|  | 
 | ||||||
|  | ARGS ?= $(EXTRA_ARGS) | ||||||
|  | 
 | ||||||
|  | .DEFAULT_GOAL := help | ||||||
|  | 
 | ||||||
|  | .PHONY: all | ||||||
|  | all: status checkmake clean build verify install docker-build docker-images ## Build the image
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 
 | ||||||
|  | .PHONY: check-env | ||||||
|  | check-env: ## Checks the environment variables
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	@echo "NAME: $(NAME)" | ||||||
|  | ifeq ($(NAME),) | ||||||
|  | 	$(error You must provide name) | ||||||
|  | endif | ||||||
|  | 	@echo "VERSION: $(VERSION)" | ||||||
|  | ifeq ($(VERSION),) | ||||||
|  | 	$(error You must provide version) | ||||||
|  | endif | ||||||
|  | 	@echo "VERSION_TAG: $(VERSION_TAG)" | ||||||
|  | 	@echo "LATEST_TAG: $(LATEST_TAG)" | ||||||
|  | 	@echo "BUILD_TAG: $(BUILD_TAG)" | ||||||
|  | ifneq ($(GITUNTRACKEDCHANGES),) | ||||||
|  | 	@echo "Changes: \n$(GITUNTRACKEDCHANGES)" | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | .PHONY: spring-clean | ||||||
|  | spring-clean: ## Cleanup git ignored files (interactive)
 | ||||||
|  | 	git clean -Xdi | ||||||
|  | 
 | ||||||
|  | .PHONY: checkmake | ||||||
|  | HAS_CHECKMAKE := $(shell which checkmake) | ||||||
|  | checkmake: ## Check this Makefile
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | ifndef HAS_CHECKMAKE | ||||||
|  | 	go get -u github.com/mrtazz/checkmake | ||||||
|  | endif | ||||||
|  | 	@checkmake Makefile | ||||||
|  | 
 | ||||||
|  | define e2e | ||||||
|  | echo "\nRunning $(1) e2e test"; | ||||||
|  | @e2e/$(1)/test.sh $(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT); | ||||||
|  | endef | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-e2e | ||||||
|  | E2E_TESTS := $(shell ls e2e) | ||||||
|  | docker-e2e: docker-build ## Make e2e tests for docker image
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	$(foreach TEST_NAME,$(E2E_TESTS), $(call e2e,$(TEST_NAME))) | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-login | ||||||
|  | docker-login: ## Log in into the Docker repository
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-build | ||||||
|  | docker-build: check-env ## Build the container
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker build . -t $(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT) --file Dockerfile | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-images | ||||||
|  | docker-images: ## List all local containers
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker images | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-push | ||||||
|  | docker-push: ## Push the container
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker tag $(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT) $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(BUILD_TAG) | ||||||
|  | 	docker push $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(BUILD_TAG) | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-release-version | ||||||
|  | docker-release-version: ## Release image with version tag (in addition to build tag)
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker tag $(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT) $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(VERSION_TAG) | ||||||
|  | 	docker push $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(VERSION_TAG) | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-release-latest | ||||||
|  | docker-release-latest: ## Release image with latest tags (in addition to build tag)
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker tag $(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT) $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(LATEST_TAG) | ||||||
|  | 	docker push $(DOCKER_ORGANIZATION)/$(DOCKER_REGISTRY)/$(NAME):$(LATEST_TAG) | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-release | ||||||
|  | docker-release: docker-release-version docker-release-latest ## Release image with version and latest tags (in addition to build tag)
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 
 | ||||||
|  | # if this session isn't interactive, then we don't want to allocate a
 | ||||||
|  | # TTY, which would fail, but if it is interactive, we do want to attach
 | ||||||
|  | # so that the user can send e.g. ^C through.
 | ||||||
|  | INTERACTIVE := $(shell [ -t 0 ] && echo 1 || echo 0) | ||||||
|  | ifeq ($(INTERACTIVE), 1) | ||||||
|  |     DOCKER_FLAGS += -t | ||||||
|  | endif | ||||||
|  | 
 | ||||||
|  | .PHONY: docker-run | ||||||
|  | docker-run: docker-build ## Run the container in docker, you can use EXTRA_ARGS
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	docker run --rm -i $(DOCKER_FLAGS) \
 | ||||||
|  | 		$(DOCKER_REGISTRY)/$(NAME):$(GITCOMMIT) $(ARGS) | ||||||
|  | 
 | ||||||
|  | .PHONY: bump-version | ||||||
|  | BUMP := patch | ||||||
|  | bump-version: ## Bump the version in the version file. Set BUMP to [ patch | major | minor ]
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	@go get -u github.com/jessfraz/junk/sembump # update sembump tool | ||||||
|  | 	$(eval NEW_VERSION=$(shell sembump --kind $(BUMP) $(VERSION))) | ||||||
|  | 	@echo "Bumping VERSION.txt from $(VERSION) to $(NEW_VERSION)" | ||||||
|  | 	echo $(NEW_VERSION) > VERSION.txt | ||||||
|  | 	@echo "Updating version from $(VERSION) to $(NEW_VERSION) in README.md" | ||||||
|  | 	sed -i s/$(VERSION)/$(NEW_VERSION)/g README.md | ||||||
|  | 	sed -i s/$(VERSION)/$(NEW_VERSION)/g deploy/operator.yaml | ||||||
|  | 	git add VERSION.txt README.md deploy/operator.yaml | ||||||
|  | 	git commit -vaem "Bump version to $(NEW_VERSION)" | ||||||
|  | 	@echo "Run make tag to create and push the tag for new version $(NEW_VERSION)" | ||||||
|  | 
 | ||||||
|  | .PHONY: tag | ||||||
|  | tag: ## Create a new git tag to prepare to build a release
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	git tag -s -a $(VERSION) -m "$(VERSION)" | ||||||
|  | 	git push origin $(VERSION) | ||||||
|  | 
 | ||||||
|  | .PHONY: help | ||||||
|  | help: | ||||||
|  | 	@grep -Eh '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}' | ||||||
|  | 
 | ||||||
|  | .PHONY: status | ||||||
|  | status: ## Shows git and dep status
 | ||||||
|  | 	@echo "+ $@" | ||||||
|  | 	@echo "Commit: $(GITCOMMIT), VERSION: $(VERSION)" | ||||||
|  | 	@echo | ||||||
|  | ifneq ($(GITUNTRACKEDCHANGES),) | ||||||
|  | 	@echo "Changed files:" | ||||||
|  | 	@git status --porcelain --untracked-files=no | ||||||
|  | 	@echo | ||||||
|  | endif | ||||||
|  | ifneq ($(GITIGNOREDBUTTRACKEDCHANGES),) | ||||||
|  | 	@echo "Ignored but tracked files:" | ||||||
|  | 	@git ls-files -i --exclude-standard | ||||||
|  | 	@echo | ||||||
|  | endif | ||||||
|  | 	@echo "Dependencies:" | ||||||
|  | 	dep status | ||||||
|  | 	@echo | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | v0.0.1 | ||||||
|  | @ -0,0 +1,15 @@ | ||||||
|  | #!/usr/bin/env bash | ||||||
|  | 
 | ||||||
|  | set -eo pipefail | ||||||
|  | 
 | ||||||
|  | [[ ! $# -eq 1 ]] && echo "Usage: $0 backup_number" && exit 1; | ||||||
|  | [[ -z "${BACKUP_DIR}" ]] && echo "Required 'BACKUP_DIR' env not set" && exit 1; | ||||||
|  | [[ -z "${JENKINS_HOME}" ]] && echo "Required 'JENKINS_HOME' env not set" && exit 1; | ||||||
|  | 
 | ||||||
|  | backup_number=$1 | ||||||
|  | echo "Running backup" | ||||||
|  | 
 | ||||||
|  | tar -C ${JENKINS_HOME} -czf "${BACKUP_DIR}/${backup_number}.tar.gz" --exclude jobs/*/config.xml --exclude jobs/*/workspace* -c jobs | ||||||
|  | 
 | ||||||
|  | echo Done | ||||||
|  | exit 0 | ||||||
|  | @ -0,0 +1,15 @@ | ||||||
|  | #!/usr/bin/env bash | ||||||
|  | 
 | ||||||
|  | set -eo pipefail | ||||||
|  | 
 | ||||||
|  | [[ ! $# -eq 1 ]] && echo "Usage: $0 backup_number" && exit 1 | ||||||
|  | [[ -z "${BACKUP_DIR}" ]] && echo "Required 'BACKUP_DIR' env not set" && exit 1; | ||||||
|  | [[ -z "${JENKINS_HOME}" ]] && echo "Required 'JENKINS_HOME' env not set" && exit 1; | ||||||
|  | 
 | ||||||
|  | backup_number=$1 | ||||||
|  | echo "Running restore backup" | ||||||
|  | 
 | ||||||
|  | tar -C ${JENKINS_HOME} -zxf "${BACKUP_DIR}/${backup_number}.tar.gz" | ||||||
|  | 
 | ||||||
|  | echo Done | ||||||
|  | exit 0 | ||||||
|  | @ -0,0 +1,4 @@ | ||||||
|  | # Setup variables for the Makefile | ||||||
|  | NAME=pvc | ||||||
|  | DOCKER_ORGANIZATION=virtuslab | ||||||
|  | DOCKER_REGISTRY=jenkins-operator/backup | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | build logs | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | 2 | ||||||
|  | @ -0,0 +1,39 @@ | ||||||
|  | #!/bin/bash | ||||||
|  | set -eo pipefail | ||||||
|  | 
 | ||||||
|  | [ "${DEBUG}" ] && set -x | ||||||
|  | 
 | ||||||
|  | # set current working directory to the directory of the script | ||||||
|  | cd "$(dirname "$0")" | ||||||
|  | 
 | ||||||
|  | docker_image=$1 | ||||||
|  | 
 | ||||||
|  | if ! docker inspect ${docker_image} &> /dev/null; then | ||||||
|  |     echo "Image '${docker_image}' does not exists" | ||||||
|  |     false | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | JENKINS_HOME="$(pwd)/jenkins_home" | ||||||
|  | BACKUP_DIR="$(pwd)/backup" | ||||||
|  | RESTORE_FOLDER="$(pwd)/restore" | ||||||
|  | mkdir -p ${BACKUP_DIR} | ||||||
|  | mkdir -p ${RESTORE_FOLDER} | ||||||
|  | 
 | ||||||
|  | # Create an instance of the container under testing | ||||||
|  | cid="$(docker run -e JENKINS_HOME=${JENKINS_HOME} -v ${JENKINS_HOME}:${JENKINS_HOME}:ro -e BACKUP_DIR=${BACKUP_DIR} -v ${BACKUP_DIR}:${BACKUP_DIR}:rw -e RESTORE_FOLDER=${RESTORE_FOLDER} -v ${RESTORE_FOLDER}:${RESTORE_FOLDER}:rw -d ${docker_image})" | ||||||
|  | echo "Docker container ID '${cid}'" | ||||||
|  | 
 | ||||||
|  | # Remove test directory and container afterwards | ||||||
|  | trap "docker rm -vf $cid > /dev/null;rm -rf ${BACKUP_DIR}" EXIT | ||||||
|  | 
 | ||||||
|  | backup_number=1 | ||||||
|  | docker exec -it ${cid} /home/user/bin/backup.sh ${backup_number} | ||||||
|  | 
 | ||||||
|  | backup_file="${BACKUP_DIR}/${backup_number}.tar.gz" | ||||||
|  | [[ ! -f ${backup_file} ]] && echo "Backup file ${backup_file} not found" && exit 1; | ||||||
|  | 
 | ||||||
|  | docker exec -it ${cid} /bin/bash -c "JENKINS_HOME=${RESTORE_FOLDER};/home/user/bin/restore.sh ${backup_number}" | ||||||
|  | 
 | ||||||
|  | echo "Compare directories" | ||||||
|  | diff --brief --recursive ${JENKINS_HOME} ${RESTORE_FOLDER} | ||||||
|  | echo "Directories are the same" | ||||||
		Loading…
	
		Reference in New Issue