「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Dockerコンテナ上でRedmineをセットアップする

Dockerコンテナ上でRedmineをセットアップする

2024 年 11 月 9 日に公開
ブラウズ:900

Setup Redmine on Docker Container

Redmine は、柔軟なオープンソースのプロジェクト管理および問題追跡 Web アプリケーションです。プロジェクトの管理、バグの追跡、タスクと期限の処理に広く使用されています。 Ruby on Rails を使用して開発された Redmine は高度にカスタマイズ可能で、チームのコラボレーションとプロジェクトの組織化のための幅広い機能をサポートしています。

Redmine は、その柔軟性、カスタマイズ性、オープンソースの性質により、商用プロジェクト管理ツールの代替として人気があります。

この記事では、データベース サーバー、mysql、リバース プロキシとして nginx とともに docker コンテナ上に redmine をセットアップします。

Dockerをインストールする

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

OK、docker がインストールされました。次に、ユーザー (ubuntu) が sudo なしで直接 docker にアクセスできるように設定する必要があります。

sudo groupadd docker
sudo usermod -aG docker $USER

その後、ログアウトしてサーバーに再度ログインします。 Docker の準備ができました!
以下のコマンドを使用して、サーバーの再起動時に Docker コンテナを起動できます。

sudo systemctl enable docker.service
sudo systemctl enable containerd.service

今のところは docker コンテナで十分です。

Docker Compose ファイルを作成する

docker compose ファイルを 1 つ作成します。

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

次に、docker-compose ファイルと同じフォルダーに nginx 設定ファイルを作成します

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 ファイルを実行すると、ネットワークが自動的に作成され、その 1 つのネットワーク内で 3 つのサービス (nginx、redmine、db) がリンクされます。

コマンドでコンテナを確認できます:

docker ps -a

次に、ポート 80 とポート 443 を使用して https 接続を使用して、ブラウザ上で Redmine アプリケーションをテストします。 Redmine アプリケーションへのログインにはユーザー「admin」とパスワード「admin」を使用してください。

この記事は、vps に直接インストールした場合と基本的に同じ結果になります。この記事を参照してください。

この記事がお役に立てば幸いです!

リリースステートメント この記事は次の場所に転載されています: https://dev.to/henri_sekeladi/setup-redmine-on-docker-container-ohk?1 侵害がある場合は、[email protected] に連絡して削除してください。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3