4dbe06e99d
It prints the containers of a stack (or specific service, if the `--service=service_name` option is set) |
||
---|---|---|
CHANGELOG.md | ||
Dockerfile | ||
LICENSE | ||
psu | ||
README.md |
Portainer Stack Utils
Bash script to deploy/update/undeploy stacks in a Portainer instance from a docker-compose yaml file. Based on previous work by @vladbabii on docker-how-to/portainer-bash-scripts.
Supported Portainer API
Script was created for the latest Portainer API, which at the time of writing is 1.19.2.
How to install
Standalone
Just clone the repo and use the script:
git clone https://github.com/greenled/portainer-stack-utils.git
cd portainer-stack-utils
./psu -a deploy ...
Requirements
You will need these dependecies installed:
For Debian and similar apt-powered systems: apt install bash httpie jq
.
Docker image
Use the published Docker image:
docker run -e ACTION=deploy greenled/portainer-stack-utils ...
See the With envvars section for a list of all supported environment variables.
Tags
Published images are tagged matching GitHub releases:
latest
,0.1.1
->0.1.1
0.1.0
->0.1.0
- ...
dev
->master
How to use
The provided psu
script allows to deploy/update/undeploy Portainer stacks. Settings can be passed through envvars and/or flags. Both envvars and flags can be mixed but flags will always overwrite envvar values. When deploying a stack, if it doesn't exist a new one is created, otherwise it's updated (unless strict mode is active).
With envvars
This is particularly useful for CI/CD pipelines using Docker containers.
ACTION
("deploy" or "undeploy", required): Whether to deploy or undeploy the stackPORTAINER_USER
(string, required): UsernamePORTAINER_PASSWORD
(string, required): PasswordPORTAINER_URL
(string, required): URL to PortainerPORTAINER_STACK_NAME
(string, required): Stack nameDOCKER_COMPOSE_FILE
(string, required if action=deploy): Path to doker-compose fileENVIRONMENT_VARIABLES_FILE
(string, optional, only used when action=deploy or action=update): Path to file with environment variables to be used by the stack. See stack environment variables below.PORTAINER_PRUNE
("true" or "false", optional): Whether to prune unused containers or not. Defaults to"false"
.PORTAINER_ENDPOINT
(int, optional): Which endpoint to use. Defaults to1
.HTTPIE_VERIFY_SSL
("yes" or "no", optional): Whether to verify SSL certificate or not. Defaults to"yes"
.VERBOSE_MODE
("true" or "false", optional): Whether to activate verbose output mode or not. Defaults to"false"
. See verbose mode below.DEBUG_MODE
("true" or "false", optional): Whether to activate debug output mode or not. Defaults to"false"
. See debug mode below.STRICT_MODE
("true" or "false", optional): Whether to activate strict mode or not. Defaults to"false"
. See strict mode below.
Examples
export ACTION="deploy"
export PORTAINER_USER="admin"
export PORTAINER_PASSWORD="password"
export PORTAINER_URL="http://portainer.local"
export PORTAINER_STACK_NAME="mystack"
export DOCKER_COMPOSE_FILE="/path/to/docker-compose.yml"
export ENVIRONMENT_VARIABLES_FILE="/path/to/env_vars_file"
./psu
export ACTION="undeploy"
export PORTAINER_USER="admin"
export PORTAINER_PASSWORD="password"
export PORTAINER_URL="http://portainer.local"
export PORTAINER_STACK_NAME="mystack"
./psu
With flags
This is more suitable for standalone script usage.
-a
("deploy" or "undeploy", required): Whether to deploy or undeploy the stack-u
(string, required): Username-p
(string, required): Password-l
(string, required): URL to Portainer-n
(string, required): Stack name-c
(string, required if action=deploy): Path to doker-compose file-g
(string, optional, only used when action=deploy or action=update): Path to file with environment variables to be used by the stack. See stack environment variables below.-r
("true" or "false", optional): Whether to prune unused containers or not. Defaults to"false"
.-e
(int, optional): Which endpoint to use. Defaults to1
.-s
("yes" or "no", optional): Whether to verify SSL certificate or not. Defaults to"yes"
.-v
("true" or "false", optional): Whether to activate verbose output mode or not. Defaults to"false"
. See verbose mode below.-d
("true" or "false", optional): Whether to activate debug output mode or not. Defaults to"false"
. See debug mode below.-t
("true" or "false", optional): Whether to activate strict mode or not. Defaults to"false"
. See strict mode below.
Examples
./psu -a deploy -u admin -p password -l http://portainer.local -n mystack -c /path/to/docker-compose.yml -g /path/to/env_vars_file
./psu -a undeploy -u admin -p password -l http://portainer.local -n mystack
Stack environment variables
There can be set environment variables for each stack, be it a new deployment or an update. For example:
touch .env
echo "MYSQL_ROOT_PASSWORD=agoodpassword" >> .env
echo "ALLOWED_HOSTS=*" >> .env
./psu -a deploy -u admin -p password -l http://portainer.local -n django-stack -c /path/to/docker-compose.yml -g env_vars
Stack environment variables can be enabled through ENVIRONMENT_VARIABLES_FILE envvar or -g flag.
Verbose mode
In verbose mode the script prints execution steps.
Getting auth token...
Getting stack mystack...
Stack mystack not found.
Getting Docker info...
Getting swarm cluster (if any)...
Swarm cluster found.
Preparing stack JSON...
Creating stack mystack...
Verbose mode can be enabled through VERBOSE_MODE envvar or -v flag.
Debug mode
In debug mode the script prints as much information as possible to help diagnosing a malfunction.
WARNING: Debug mode will print configuration values (with Portainer credentials) and Portainer API responses (with sensitive information like authentication token and stacks environment variables). Avoid using debug mode in CI/CD pipelines, as pipeline logs are usually recorded.
Debug mode can be enabled through DEBUG_MODE envvar or -d flag.
Strict mode
In strict mode the script never updates an existent stack nor removes an unexistent one, and instead exits with an error.
Strict mode can be enabled through STRICT_MODE envvar or -t flag.
License
Source code contained by this project is licensed under the GNU General Public License version 3. See LICENSE file for reference.