Faça o deploy de mais de 10+ open-source apps usando os templates do Portainer ou com um único comando. E para quem quer segurança com suporte a secrets do docker.
Tip
Sem necessidade de gerenciar .envs, mas com opção ainda disponivel para quem precisar
Tip
Compatibilidade com (GlusterFS, Ceph, NFS) usando VOLUME_PATH=/mnt/
Tip
Já prontas para instalação via comando DOMAIN=subdominio.seudominio.com e com diponibilidade do arquivo .env.
Warning
Guarde suas chaves em um local seguro.
Chega de ficar procurando no google por arquivos do docker compose para implantar no seu servidor
Aplicativos configurados e personalizados ao máximo para implantação em pouquissimos passos.
- Aberto para contribuição - Qualquer pessoa pode mandar os requests e consertar erros e fornecer atualizações para as versões das aplicações.
- Implantação simples - Stacks prontas, com documentação e detalhes sobre cada variável em português.
- Compatibilidade com Swarm e Portainer - Templates prontos para produção com tudo semi configurado para deploy em servidores pronto para uso.
São usadas variáveis para que você economize tempo ao setar vários aplicativos e não precise digitar seu email ou senha todas as vezes que for fazer o deploy de uma stack.
Veja aqui as variáveis padrão do one click stacks.
- DOMINIO - Seu dominio padrão. Ex: seudominio.com.br
- ACME_EMAIL - Email usado para aquisição dos certificados Let's Encrypt. SUPER IMPORTANTE
- SMTP_SENDER - Email que irá aparecer quando se envia um email novo pelo servidor. Ex: [email protected]
- SMTP_SERVER - Endereço do servidor SMTP que irá enviar os emails. Ex: gmail.smtp.com ou mail.seudominio.com
- SMTP_USER - Usuário que ira logar no servidor SMTP, normalmente é seu email principal. Ex: [email protected]
- SMTP_PASSWORD - Senha do seu email ou senha de aplicativo. Saiba mais sobre senhas de aplicativo
- NUMBER - Uma aplicação pode ter varias instancias rodando, -1 -2 -3 -4, se não alterada o padrão será -1. Ex: Portainer-1
- VERSION - A versão da aplicação a ser usada no container, se não alterada será usada a ultima versão estável do aplicativo.
- TRUSTED_IPS - IP dos servidores que vão se conectar a suas aplicações, se não alterado o padrão sera somente o localhost.
Recomendado somente o uso de variáveis em senhas para testes ou desenvolvimento, estou adicionando suporte a secrets por padrão para que você tenha mais segurança no deploy, como uso com clientes essas stacks, achei necessário adicionar o suporte a elas.
Variáveis também serão disponibilizadas em arquivos .env para maior controle para quem quiser implantar pelo docker stack compose ou via interface web do Portainer.
No ambiente de deploy, ou seja, fora dos testes recomendo fortemente o uso de secrets, que normalmente .
Instalar dependências:
sudo apt-get update
sudo apt-get install \
ca-certificates \
curl \
gnupg \
lsb-release
Instalar o docker:
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
Criar o ambiente swarm:
docker swarm init
docker network create --driver=overlay traefik-public
Note
Usamos o Portainer como padrão então ele é a única stack que precisa ser instalada via linha de comando.
Acessar sua pasta de usuário:
cd ~
Clonar o repositório:
git clone https://github.com/matheusmaiberg/Stacks-Incriveis.git
Acessar a pasta do repositório:
cd Stacks-Incriveis
SUBDOMINIO=portainer \
DOMINIO=seudominio.com.br \
docker stack deploy -c portainer/portainer.yml superstack
curl https://ipv4.am.i.mullvad.net/port/80
curl https://ipv4.am.i.mullvad.net/port/443
Warning
Seu portainer ainda não estará exposto em subdominio por que o Traefik não foi instalado ainda, mas está pré configurado na porta vps_ip:9000, acesse ele para instalar o Traefik e outras stacks.
A Stacks Incriveis segue a seguinte estrutura nesse repositório.
- Repositório
- Pasta da stack
- stack.yml
- .env
- Pasta da stack
Warning
Na stack do portainer já tem uma configuração que as stacks são vinculadas com o arquivo templates.json da Stacks Incriveis, caso voce já tenha pré instalado o Portainer terá que adicionar o link do template json as configurações do seu Portainer em Settings > App templates e colar a url do arquivo templates.json.
Acesse App Templates > Copy as Custom > Create custom template > Stacks > Add stack > Custom Template
Via comando CLI:
DOMAIN=<subdominio.meudominio.com.br> docker stack deploy -c <stack.yml> <nome_da_aplicação>
Exemplo:
DOMAIN=n8n.seudominio.com.br docker stack deploy -c stacks/n8n.yml n8n
Na stack do container já tem uma configuração que as stacks são vinculadas com o arquivo templates.json da one click stacks.
Você pode acessar as stacks de dentro do portainer, facilitando ainda mais o deploy e também garante que todas stacks estejam sempre atualizadas.