- Synology NAS의 Container Manager를 이용하여 설치하기
- Docker Image 선택
- Redmine에 사용할 Data Base 선택
- 4. Portainer 설치 여부

레드마인(Redmine)은 루비 온 레일즈 기반의 오픈소스 프로그램으로 웹 기반의 프로젝트 관리 도구이다.
프로젝트 별로 일이 어떻게 진행되는지 화면 기반으로 볼 수 있도록 달력과 간트 차트, 트리구조의 시각화(Easy WBS)를 제공한다.
무료로 사용이 가능하다는 것을 제외하면, 모두 단점이다.
제공되는 플러그인도 버전 업그레이드 시 오류 발생의 빈도가 높아 주의해야 할 점이다.
1. Synology NAS의 Container Manager를 이용하여 설치하기
이 블로그에서는 다음과 같은 이미지와 데이터베이스를 사용하여 Redmine을 설치하는 과정을 정리한 글이다.
- redmine:latest (5.0.5)
- postgre:latest (15.3-1.pgdg120+1)

2. Docker Image 선택
Redmine은 프로젝트 관리 및 이슈 추적을 위한 오픈 소스 웹 응용 프로그램이다. 하지만 Redmine을 설치하는 데에는 여러 가지 방법이 있으며, 각각의 설치 방법은 서로 다른 개발자나 그룹에 의해 관리되고 유지보수된. 주요 차이점을 살펴보겠다.
- Redmine: Redmine 공식 웹사이트 (https://www.redmine.org/) 에서 제공하는 소스 코드를 직접 다운로드하여 설치하는 방법이다. 이렇게 설치하면 최신 버전을 사용하게 되지만 모든 구성과 설정은 사용자가 수동으로 처리해야 한다.
- Bitnami/Redmine: Bitnami는 애플리케이션을 쉽게 설치하고 배포하기 위한 무료 서비스를 제공한다. Bitnami에서는 미리 구성된 Redmine 패키지를 제공하여 사용자가 수동으로 설치하고 구성할 필요 없이 빠르게 설치할 수 있게 한다.
- sameersbn/Redmine: sameersbn은 Docker 컨테이너로 Redmine을 실행할 수 있도록 준비한 개인 개발자의 GitHub 프로젝트이다. Docker를 사용하여 Redmine을 쉽게 배포하고 실행할 수 있으며, 개발자가 관리하고 업데이트한다.
- Turnkey Linux/Redmine: Turnkey Linux는 사용자가 사용하고자 하는 애플리케이션을 미리 설치하여 제공하는 리눅스 기반의 가상 머신 이미지를 제공한다. Turnkey Linux의 Redmine 이미지는 Redmine을 미리 설치하고 구성하여 사용자가 쉽게 시작할 수 있도록 되어 있다.
이러한 방법들은 Redmine을 쉽게 설치하고 운영하는 데 도움이 된다. 선택하는 방법은 개인 또는 조직의 선호도, 기술 수준, 배포 방식 등을 고려해야 한다. 각각의 방법은 업데이트와 유지보수의 접근성, 커스터마이징 가능성, 사용자 편의성 등에 차이가 있을 수 있다.
3. Redmine에 사용할 Data Base 선택
MySQL, PostgreSQL, SQLite은 모두 데이터베이스 관리 시스템(DBMS)으로서 데이터를 저장, 관리, 검색하는 역할을 합니다. 그러나 각각은 목적과 특성에 따라 다음과 같은 주요 차이점이 있다:
- MySQL:
- 타입: MySQL은 관계형 데이터베이스 관리 시스템(RDBMS)로, 가장 널리 사용되는 오픈 소스 데이터베이스이다.
- 라이선스: MySQL은 Oracle Corporation이 소유하고 있으며, 두 가지 버전이 있다. MySQL Community Edition(무료)과 MySQL Enterprise Edition(유료)가 있다.
- 성능: 대규모 트래픽에도 효율적으로 동작하며, 속도가 빠른 편이다.
- 사용: 대부분의 웹 응용 프로그램, 웹 사이트, 서버 애플리케이션 등에서 많이 사용된다.
- PostgreSQL:
- 타입: PostgreSQL은 또 다른 인기 있는 오픈 소스 관계형 데이터베이스 관리 시스템(RDBMS)이다.
- 라이선스: PostgreSQL은 오픈 소스이며, 무료로 사용할 수 있다. 또한 라이브러리를 수정하여 상용 제품으로도 판매할 수 있다.
- 기능: 매우 강력한 기능을 제공하며, 트랜잭션 처리, 외래 키, 뷰, 스토어드 프로시저 등을 포함한 다양한 기능을 지원한다.
- 확장성: 높은 확장성을 갖고 있으며, 대규모 데이터베이스 시스템에서 안정적으로 동작한다.
- 사용: 대규모 애플리케이션, 데이터 웨어하우스, GIS(지리정보시스템) 등에서 많이 사용된다.
- SQLite:
- 타입: SQLite은 경량의 오픈 소스 데이터베이스 관리 시스템(RDBMS)으로서, 서버가 아닌 개별 디바이스 또는 애플리케이션에 내장하여 사용할 수 있다.
- 라이선스: 오픈 소스이며, 라이선스 문제나 추가 비용 없이 무료로 사용할 수 있다.
- 설정: 별도의 서버 설치나 관리가 필요 없이 단일 파일 또는 메모리에 데이터베이스를 저장한다.
- 사용: 작은 규모의 애플리케이션, 모바일 앱, 임베디드 시스템 등에서 많이 사용된다.
요약하면, MySQL은 대규모 웹 애플리케이션에 적합하며, PostgreSQL은 높은 기능과 확장성을 갖춘 대규모 애플리케이션에 적합하고, SQLite은 경량의 개별 디바이스나 애플리케이션에 내장하여 사용하기에 적합하다. 선택은 애플리케이션의 요구사항과 환경에 따라 달라진다.
4. Container Manager 와 Portainer 의 차이점
Portainer와 Synology NAS의 Container Manager는 모두 Docker 컨테이너 관리 도구이다. 그러나 몇 가지 주요 차이점이 있다:
- Portainer:
- 독립적인 솔루션: Portainer는 독립적인 오픈 소스 도구로, 다양한 플랫폼에서 Docker를 관리하기 위해 사용된다. 사용자는 Portainer를 설치하고 설정한 후에 웹 인터페이스를 통해 Docker 호스트를 관리할 수 있다.
- 다양한 환경 지원: Portainer는 Docker 호스트를 여러 플랫폼과 환경에서 관리할 수 있다. 개인 서버, 클라우드 서버, 가상 머신 등 어디서든 Docker 호스트에 연결하여 사용할 수 있다.
- Synology NAS의 Container Manager:
- Synology NAS 특화: Synology NAS의 Container Manager는 Synology NAS용으로 설계된 기능이다. Synology NAS는 소형 기업 및 개인 사용자들이 네트워크 스토리지 및 서버 솔루션을 쉽게 운영할 수 있도록 제공하는 네트워크 어플라이언스이다.
- NAS 통합 관리: Container Manager는 Synology DSM(DiskStation Manager) 운영 체제와 밀접하게 통합되어 있으며, NAS의 웹 인터페이스에서 직접 접근하여 사용할 수 있다.
- 간편한 설정: Container Manager는 Synology NAS에서 Docker를 실행하는 데 필요한 모든 설정을 간단히 제공한다. 사용자들은 별도의 설치나 구성 없이 Synology NAS에서 Docker 컨테이너를 관리할 수 있다.
요약하면, Portainer는 Docker 컨테이너 관리 도구로 독립적인 오픈 소스 프로젝트로, 다양한 플랫폼에서 Docker 호스트를 관리한다. 반면에 Synology NAS의 Container Manager는 Synology NAS에 특화된 Docker 관리 도구로, Synology NAS 운영 체제와 통합되어 NAS에서 간단하게 Docker 컨테이너를 관리할 수 있도록 한다. 선택은 사용자의 요구사항과 운영 환경에 따라 달라진다.
