Redmine é um aplicativo da web flexível e de código aberto para gerenciamento de projetos e rastreamento de problemas. É amplamente utilizado para gerenciar projetos, rastrear bugs e lidar com tarefas e prazos. Desenvolvido em Ruby on Rails, o Redmine é altamente personalizável e oferece suporte a uma ampla gama de recursos para colaboração em equipe e organização de projetos.
Redmine é uma alternativa popular às ferramentas de gerenciamento de projetos comerciais devido à sua flexibilidade, personalização e natureza de código aberto.
Neste artigo, configuraremos o redmine no contêiner docker junto com o servidor de banco de dados, mysql e também nginx como proxy reverso.
Usamos o servidor Ubuntu hospedado no AWS EC2 e o guia de instalação do docker oficial.
# Add Docker's official GPG key: sudo apt-get update sudo apt-get install ca-certificates curl sudo install -m 0755 -d /etc/apt/keyrings sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc sudo chmod a r /etc/apt/keyrings/docker.asc # Add the repository to Apt sources: echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \ $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null sudo apt-get update
Usamos a versão mais recente do docker junto com o docker compose.
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
Ok, docker instalado, em seguida precisamos configurar nosso usuário (ubuntu) para poder acessar o docker diretamente sem sudo.
sudo groupadd docker sudo usermod -aG docker $USER
e então saia e faça login novamente em nosso servidor. Docker está pronto!
Podemos usar este comando abaixo para iniciar o contêiner docker quando nosso servidor for reiniciado.
sudo systemctl enable docker.service sudo systemctl enable containerd.service
docker container é suficiente por enquanto.
Criaremos um arquivo docker compose.
nano docker-compose.yaml
e cole este código yaml.
version: '3.1' services: nginx: # we use the latest of nginx as base image: nginx:latest restart: always # we expose port 80 and 443 to the public as our reverse proxy ports: - "80:80" - "443:443" volumes: # we link volume from host for nginx configuration - './nginx.conf:/etc/nginx/conf.d/nginx.conf' # we link volume from host for nginx certs - './certs:/etc/nginx/certs' # we link also timezone from the host - '/etc/localtime:/etc/localtime:ro' - '/etc/timezone:/etc/timezone:ro' depends_on: # we will wait until server redmine is ready - redmine redmine: # we use redmine from dockerhub as base image: redmine restart: always volumes: # we link redmine data to our local storage, so it will persistent when # the service redmine restarted - 'redmine_data:/usr/src/redmine/files' # we link redmine plugin also from the host - '/home/bkn/redmine_plugins:/usr/src/redmine/plugins' # we link also timezone from the host - '/etc/localtime:/etc/localtime:ro' - '/etc/timezone:/etc/timezone:ro' # we don't expose port on this service because nginx service will do # default port redmine expose internally is 3000 #ports: #- 3000:3000 #- 444:3000 environment: # we create some env for redmine REDMINE_DB_MYSQL: db REDMINE_DB_PORT: 3306 REDMINE_DB_DATABASE: redmine_db REDMINE_DB_USERNAME: redmine REDMINE_DB_PASSWORD: my_p@ssword REDMINE_SECRET_KEY_BASE: G75eddsecretkey # we will wait until db service is ready depends_on: - db db: # we use mysql server for redmine database image: mysql:8.0 restart: always volumes: # we also link the database storage with volume we created below - 'mysql_data:/var/lib/mysql' environment: # we create some env for mysql MYSQL_USER: redmine MYSQL_PASSWORD: my_p@ssword MYSQL_RANDOM_ROOT_PASSWORD: 1 MYSQL_ROOT_PASSWORD: JRFFHT534rth4u3!@# MYSQL_DATABASE: redmine_db volumes: # we create two volume used by redmine and our database mysql_data: driver: local redmine_data: driver: local
em seguida, criamos o arquivo de configuração nginx, mesma pasta do arquivo docker-compose
nano nginx/nginx.conf
server { listen 80; server_name proman.withenri.tech; location / { proxy_pass http://henri_redmine_1:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } server { listen 443 ssl; server_name proman.withenri.tech; ssl_certificate /etc/nginx/certs/withenri.tech_chained.crt; ssl_certificate_key /etc/nginx/certs/withenri.tech.key; location / { proxy_pass http://henri_redmine_1:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
e crie uma pasta chamada certs e coloque nossos certificados ali.
vamos executar nosso arquivo docker compose com o comando
docker-compose up -d
quando executamos este arquivo docker compose, uma rede será criada automaticamente e vinculará três serviços (nginx, redmine, db) nessa rede.
podemos verificar nosso contêiner com o comando:
docker ps -a
e então teste o aplicativo redmine em nosso navegador com porta 80 e porta 443 com conexão https. use o usuário 'admin' e a senha 'admin' para fazer login em nosso aplicativo redmine.
este artigo basicamente tem o mesmo resultado quando instalamos diretamente no vps, consulte este artigo.
Espero que este artigo ajude você!
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3