Docker container for DreamFactory 5.x using Ubuntu 22.04, PHP 8.1 and NGINX.
Get Started Guide ∙ Try Online ∙ Contribute ∙ Community Support ∙ Docs
- Prerequisites
- Installation
- DreamFactory Licensed Edition
- Persisting Data
- Testing Data
- Documentation
- Commercial Licenses
- Feedback
The easiest way to configure the DreamFactory application is to use docker-compose. This will automatically spin up 4 containers, the DreamFactory application, MySQL container for the system database, Redis container for caching, and a Postgres database with over 100k records preconfigured for testing.
cd ~/repos
(or wherever you want the clone of the repo to be)
git clone https://github.com/dreamfactorysoftware/df-docker.git
cd df-docker
docker-compose build
docker-compose up -d
NOTE: volume df-storage:/opt/dreamfactory/storage is created to store all file based (apps, logs etc.) data from DreamFactory.
This basically stores all data written by DreamFactory (at /opt/dreamfactory/storage location) in the df-storage volume. This
way if you delete your DreamFactory container your data will persist as long as you don't delete the df-storage volume.
to stop and remove all containers you can use the command
docker-compose down
to stop and remove all containers including volumes use
docker-compose down -v
Go to 127.0.0.1
in your browser. It will take some time upon building, but you will be asked to create your first admin user.
docker-compose build
docker-compose up -d
Go to 127.0.0.1
in your browser. It will take some time upon building, but you will be asked to create your first admin user.
After you have spun up your DreamFactory instance, take the APP_KEY value from the .env
file in /opt/dreamfactory
. This can be done with the following command:
docker-compose exec web cat .env | grep APP_KEY
Set this value as the APP_KEY value in the docker-compose.yml file (line 19), encapsulating it in single quotes, to avoid receiving "The MAC is invalid" errors within your instance should you ever need to rebuild.
We mount a Postgres container that contains over 100k records to test without connecting your own data sets. To utilize the container you will use the following connection details.
Host: The host can be found by running the following Docker command: docker inspect <container-id> | grep "IPAddress"
Port: 5432
Database Name: dellstore
Username: postgres
Password: root_pw
This will generate a fully documented and secure API from the Postgres container.
Learn more about DreamFactory's many features by reading our Getting Started Guide. Additional platform documentation can be found on the DreamFactory wiki.
In need of official technical support? Desire access to REST API generators for SQL Server, Oracle, SOAP, or mobile push notifications? Require API limiting and/or auditing? Schedule a demo with our team!
Feedback is welcome on our forum or in the form of pull requests and/or issues. Contributions should follow the strategy outlined in "Contributing to a project".