mirror of
https://github.com/opf/openproject-deploy.git
synced 2026-02-14 16:59:51 +00:00
Reimport docker-compose
This commit is contained in:
1
.env.example
Normal file
1
.env.example
Normal file
@@ -0,0 +1 @@
|
|||||||
|
PORT=8080
|
||||||
44
README.md
44
README.md
@@ -2,4 +2,48 @@
|
|||||||
|
|
||||||
Recipes and examples for deploying OpenProject using Docker, Docker Compose, Kubernetes, etc.
|
Recipes and examples for deploying OpenProject using Docker, Docker Compose, Kubernetes, etc.
|
||||||
|
|
||||||
|
## Docker Compose
|
||||||
|
|
||||||
|
### Install
|
||||||
|
|
||||||
|
Clone this repository:
|
||||||
|
|
||||||
|
git clone https://github.com/opf/openproject-deploy --depth=1 --branch=stable/11 openproject
|
||||||
|
|
||||||
|
Go to the folder that was just created:
|
||||||
|
|
||||||
|
cd openproject
|
||||||
|
|
||||||
|
Launch the containers:
|
||||||
|
|
||||||
|
docker-compose up -d
|
||||||
|
|
||||||
|
After a while, OpenProject should be up and running on <http://localhost:8080>.
|
||||||
|
|
||||||
|
### Configuration
|
||||||
|
|
||||||
|
If you want to specify a different port, you can do so with:
|
||||||
|
|
||||||
|
PORT=4000 docker-compose up -d
|
||||||
|
|
||||||
|
If you want to specify a custom tag for the OpenProject docker image, you can do so with:
|
||||||
|
|
||||||
|
TAG=my-docker-tag docker-compose up -d
|
||||||
|
|
||||||
|
You can also set those variables into an `.env` file at the root of the
|
||||||
|
directory, and Docker Compose will pick it up automatically. See `.env.example`
|
||||||
|
for details.
|
||||||
|
|
||||||
|
### Uninstall
|
||||||
|
|
||||||
|
You can remove the stack with:
|
||||||
|
|
||||||
|
docker-compose down
|
||||||
|
|
||||||
|
### Troubleshooting
|
||||||
|
|
||||||
|
You can look at the logs with:
|
||||||
|
|
||||||
|
docker-compose logs -n 1000
|
||||||
|
|
||||||
For the complete documentation, please refer to https://docs.openproject.org/installation-and-operations/.
|
For the complete documentation, please refer to https://docs.openproject.org/installation-and-operations/.
|
||||||
|
|||||||
98
docker-compose.yml
Normal file
98
docker-compose.yml
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
version: "3.7"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
frontend:
|
||||||
|
backend:
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
pgdata:
|
||||||
|
opdata:
|
||||||
|
|
||||||
|
x-op-restart-policy: &restart_policy
|
||||||
|
restart: unless-stopped
|
||||||
|
x-op-image: &image
|
||||||
|
image: openproject/community:${TAG:-11}
|
||||||
|
x-op-app: &app
|
||||||
|
<<: *image
|
||||||
|
<<: *restart_policy
|
||||||
|
environment:
|
||||||
|
RAILS_CACHE_STORE: "memcache"
|
||||||
|
OPENPROJECT_CACHE__MEMCACHE__SERVER: "cache:11211"
|
||||||
|
OPENPROJECT_RAILS__RELATIVE__URL__ROOT: "${OPENPROJECT_RAILS__RELATIVE__URL__ROOT:-}"
|
||||||
|
DATABASE_URL: "postgres://postgres:p4ssw0rd@db/openproject"
|
||||||
|
USE_PUMA: "true"
|
||||||
|
# set to true to enable the email receiving feature. See ./docker/cron for more options
|
||||||
|
IMAP_ENABLED: "${IMAP_ENABLED:-false}"
|
||||||
|
volumes:
|
||||||
|
- "opdata:/var/openproject/assets"
|
||||||
|
|
||||||
|
services:
|
||||||
|
db:
|
||||||
|
image: postgres:10
|
||||||
|
<<: *restart_policy
|
||||||
|
stop_grace_period: "3s"
|
||||||
|
volumes:
|
||||||
|
- "pgdata:/var/lib/postgresql/data"
|
||||||
|
environment:
|
||||||
|
POSTGRES_PASSWORD: p4ssw0rd
|
||||||
|
POSTGRES_DB: openproject
|
||||||
|
networks:
|
||||||
|
- backend
|
||||||
|
|
||||||
|
cache:
|
||||||
|
image: memcached
|
||||||
|
<<: *restart_policy
|
||||||
|
networks:
|
||||||
|
- backend
|
||||||
|
|
||||||
|
proxy:
|
||||||
|
<<: *image
|
||||||
|
<<: *restart_policy
|
||||||
|
command: "./docker/proxy"
|
||||||
|
ports:
|
||||||
|
- "${PORT:-8080}:80"
|
||||||
|
environment:
|
||||||
|
APP_HOST: web
|
||||||
|
OPENPROJECT_RAILS__RELATIVE__URL__ROOT: "${OPENPROJECT_RAILS__RELATIVE__URL__ROOT:-}"
|
||||||
|
depends_on:
|
||||||
|
- web
|
||||||
|
networks:
|
||||||
|
- frontend
|
||||||
|
|
||||||
|
web:
|
||||||
|
<<: *app
|
||||||
|
command: "./docker/web"
|
||||||
|
networks:
|
||||||
|
- frontend
|
||||||
|
- backend
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
|
- cache
|
||||||
|
- seeder
|
||||||
|
|
||||||
|
worker:
|
||||||
|
<<: *app
|
||||||
|
command: "./docker/worker"
|
||||||
|
networks:
|
||||||
|
- backend
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
|
- cache
|
||||||
|
- seeder
|
||||||
|
|
||||||
|
cron:
|
||||||
|
<<: *app
|
||||||
|
command: "./docker/cron"
|
||||||
|
networks:
|
||||||
|
- backend
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
|
- cache
|
||||||
|
- seeder
|
||||||
|
|
||||||
|
seeder:
|
||||||
|
<<: *app
|
||||||
|
command: "./docker/seeder"
|
||||||
|
restart: on-failure
|
||||||
|
networks:
|
||||||
|
- backend
|
||||||
Reference in New Issue
Block a user