Redmine 是一个灵活的开源项目管理和问题跟踪 Web 应用程序。它广泛用于管理项目、跟踪错误以及处理任务和截止日期。 Redmine 使用 Ruby on Rails 开发,具有高度可定制性,支持广泛的团队协作和项目组织功能。
Redmine 因其灵活性、定制性和开源特性而成为商业项目管理工具的流行替代品。
在本文中,我们将在 docker 容器上设置 redmine 以及数据库服务器、mysql 和 nginx 作为反向代理。
我们使用托管在AWS EC2上的ubuntu服务器和docker官方的安装指南。
# 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
我们使用最新版本的 docker 以及 docker compose。
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
好了,docker安装完毕,接下来我们需要配置我们的用户(ubuntu)可以直接访问docker,无需sudo。
sudo groupadd docker sudo usermod -aG docker $USER
然后注销并再次登录我们的服务器。 Docker 已准备就绪!
我们可以使用下面的命令在服务器重新启动时启动 docker 容器。
sudo systemctl enable docker.service sudo systemctl enable containerd.service
docker 容器目前就足够了。
我们将创建一个 docker compose 文件。
nano docker-compose.yaml
并粘贴此 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
接下来,我们创建 nginx 配置文件,与 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; } }
并创建名为 certs 的文件夹,然后将我们的证书放在那里。
让我们使用命令运行我们的 docker compose 文件
docker-compose up -d
当我们运行这个 docker compose 文件时,将自动创建一个网络并链接这些网络中的三个服务(nginx、redmine、db)。
我们可以使用命令检查我们的容器:
docker ps -a
然后在我们的浏览器上使用端口 80 和端口 443 以及 https 连接测试 redmine 应用程序。使用用户“admin”和密码“admin”登录我们的 redmine 应用程序。
这篇文章和我们直接安装在vps上基本是一样的,参考这篇文章。
希望这篇文章对您有帮助!
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3