Self Hosting GrowthBook
GrowthBook consists of a NextJS front-end, an ExpressJS API, and a Python stats engine. Everything is bundled together in a single Docker Image.
In addition to the app itself, you will also need a MongoDB instance to store login credentials, cached experiment results, and metadata.
Installation
You can use docker-compose to get started quickly:
# docker-compose.yml
version: "3"
services:
mongo:
image: "mongo:latest"
environment:
- MONGO_INITDB_ROOT_USERNAME=root
- MONGO_INITDB_ROOT_PASSWORD=password
growthbook:
image: "growthbook/growthbook:latest"
ports:
- "3000:3000"
- "3100:3100"
depends_on:
- mongo
environment:
- MONGODB_URI=mongodb://root:password@mongo:27017/
volumes:
- uploads:/usr/local/src/app/packages/back-end/uploads
volumes:
uploads:
Then, just run docker-compose up -d
to start everything and view the app at http://localhost:3000
Docker Tags
Builds are published automatically from the GitHub repo main branch. The most recent commit is tagged with latest
.
GitHub Releases are also tagged using SemVer (e.g. 0.2.1
).
If you need to reference the image for a specific git commit for any reason, you can use the git shorthash tag (e.g. git-41278e9
).
Updating to Latest
If you are using docker-compose, and assuming you specify the growthbook container with :latest
, you can update with:
docker-compose pull growthbook
docker-compose stop growthbook
docker-compose up -d growthbook