Unless you have a special need we recommend that you start with the "Official" Mura Docker Image.
The "Official" Mura Docker Image, is maintained at https://hub.docker.com/r/blueriver/mura/. An example using this image is also included.
A useful example of using the "Official" Docker Image for theme development can be found at https://github.com/blueriver/MuraBootstrap4.
The Docker files in this repository may be used to create your own custom Docker container for running Mura. For Docker images, visit the Docker repository at https://hub.docker.com/r/blueriver/docker-muracms/.
NOTE: The example files and Docker images are provided as learning tools only. They are NOT intended for production purposes. That said, you could easily use the information as a basis for creating your own custom Docker images for integration into your team's workflow.
blueriver/mura:latest
(Dockerfile)- The "Official" Blue River Mura Docker image.
:7.1-commandbox-lucee5
(Dockerfile)- Uses the
:lucee5
CommandBox Docker image as the base image.
- Uses the
:7.1-commandbox-adobe2016
(Dockerfile)- Uses the
:adobe2016
CommandBox Docker image as the base image.
- Uses the
:7.1-lucee5
(Dockerfile)- Uses the
:lucee5
Lucee Docker image as the base image.
- Uses the
The Docker images and files included here are for developers to use as they consider options for integrating Docker & Mura into their workflow.
Primary thoughts to consider when implementing Docker and Mura into your workflow include:
- Which CFML engine do you want to use? Adoble ColdFusion? Or Lucee?
- Do you want to use one of the convenient Commandbox images for your desired CFML engine, or roll your own?
- Which database engine do you wish to use? MySQL, Postgres, or Microsoft SQL Server?
- Do you want to be able to modify Mura core files, and only abstract the CFML engine? (Rare)
- Do you want to abstract Mura core files, and simply have them included in the image itself? (Common)
- If abstracting Mura core files, do you want to be able to modify
modules
,plugins
,sites
, and/orthemes
? (Common)
Once you have the answers to these questions, you will be able to better select the appropriate Docker image, and docker-compose
files to use. That said, feel free to play around with all of the included examples.
While some users visiting this repository may have a strong understanding of Docker, and how it works, there are likely others who are completely new to Docker, and don't know where to start.
If you're completely new to Docker, the Docker Documentation area is a tremendous resource. You will also find the Udemy course titled "Docker Mastery: The Complete Toolset From a Docker Captain" extremely helpful in getting you up to speed rather quickly.
The following information assumes you have a copy of the docker-muracms Github repository on your local machine.
- To build your own images, you may use one of the
Dockerfile
and/ordocker-compose.yml
files located under any of the examples. - Modify the
Dockerfile
and/ordocker-compose.yml
file as desired, then build your image. (e.g.,$ docker-compose build --no-cache
)
Examples are located under https://github.com/blueriver/docker-muracms/tree/master/examples. Each example contains a docker-compose.yml
file. Using your terminal, you may cd
into the desired example directory, and then issue the $ docker-compose up
command.
Unless you've modified any of the docker-compose.yml
files, the information outlined below for each example should be correct. Feel free to inspect the docker-compose.yml
files to confirm, and/or to modify as desired.
This example uses the "Official" Mura Docker image as the base image. It abstracts the Mura core files, and includes host directories under the www
directory for editing modules
, plugins
, sites
, and themes
. The MySQL database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/blueriver-muracms-mysql
directory.
- Website:
- Image: "Official" Mura Docker Image (blueriver/mura:latest)
- Domain: http://localhost:8001
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: MySQL (mysql:5.7.19)
- Domain: http://localhost:5001
- Usr:
root
- Pwd:
5trongP@55w0rd
- Usr:
This example uses the CommandBox Adobe2016 image as the base image. It abstracts the Mura core files, and includes host directories under the www
directory for editing modules
, plugins
, sites
, and themes
. The Microsoft SQL Server database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/commandbox-adobe2016-mssql
directory.
To build a new image (to get the latest updates) and then run it, use $ docker-compose build --no-cache && docker-compose up
. Your site should be available, after the scripts have finished running.
- Website:
- Image: blueriver/docker-muracms:7.1-commandbox-adobe2016
- Domain: http://localhost:8002
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: Microsoft SQL Server (microsoft/mssql-server-linux:latest)
- Domain: http://localhost:5002
- Usr:
sa
- Pwd:
5trongP@55w0rd
- Usr:
This example uses the CommandBox Lucee5 image as the base image. It abstracts the Mura core files, and includes host directories under the www
directory for editing modules
, plugins
, sites
, and themes
. The MySQL database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/commandbox-lucee5-mysql
directory.
To build a new image (to get the latest updates) and then run it, use $ docker-compose build --no-cache && docker-compose up
. Your site should be available, after the scripts have finished running.
- Website:
- Image: blueriver/docker-muracms:7.1-commandbox-lucee5
- Domain: http://localhost:8003
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: MySQL (mysql:5.7.19)
- Domain: http://localhost:5003
- Usr:
root
- Pwd:
5trongP@55w0rd
- Usr:
This example also uses the CommandBox Lucee5 image as the base image. It abstracts the Mura core files, and includes host directories under the www
directory for editing modules
, plugins
, sites
, and themes
. The Postgres database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/commandbox-lucee5-postgres
directory.
To build a new image (to get the latest updates) and then run it, use $ docker-compose build --no-cache && docker-compose up
. Your site should be available, after the scripts have finished running.
- Website:
- Image: blueriver/docker-muracms:7.1-commandbox-lucee5
- Domain: http://localhost:8004
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: Postgres (postgres:9.6.5-alpine)
- Domain: http://localhost:5004
- Usr:
muradb
- Pwd:
5trongP@55w0rd
- Usr:
This example uses the Lucee Lucee5 image as the base image. It abstracts the Mura core files, and includes host directories under the www
directory for editing modules
, plugins
, sites
, and themes
. The MySQL database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/lucee5-mysql
directory.
To build a new image (to get the latest updates) and then run it, use $ docker-compose build --no-cache && docker-compose up
. Your site should be available, after the scripts have finished running.
- Website:
- Image: blueriver/docker-muracms:7.1-lucee5
- Domain: http://localhost:8005
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: MySQL (mysql:5.7.19)
- Domain: http://localhost:5005
- Usr:
root
- Pwd:
5trongP@55w0rd
- Usr:
This example uses the Lucee Lucee5 image as the base image. It abstracts the Mura core files, and also abstracts the modules
, plugins
, sites
, and themes
directories. In other words, all changes are stored in the mounted volumes
. The MySQL database image is added in the docker-compose.yml
file. To run this example "as-is", you should be able to simply run $ docker-compose up
from within the examples/lucee5-mysql-nofiles
directory. To view the volumes created, you can always run $ docker image ls
.
To build a new image (to get the latest updates) and then run it, use $ docker-compose build --no-cache && docker-compose up
. Your site should be available, after the scripts have finished running.
- Website:
- Image: blueriver/docker-muracms:7.1-lucee5
- Domain: http://localhost:8005
- Usr:
admin
- Pwd:
5trongP@55w0rd
- Usr:
- Database:
- Image: MySQL (mysql:5.7.19)
- Domain: http://localhost:5005
- Usr:
root
- Pwd:
5trongP@55w0rd
- Usr:
The example below uses the "Official" Mura image, along with MySQL.
Running $ docker-compose up
with the file below would be accessible via http://localhost:8888
.
version: '3.3'
services:
mura:
image: blueriver/mura:latest
depends_on:
- svc_muradb
environment:
MURA_ADMIN_USERNAME: admin
MURA_ADMIN_PASSWORD: 5trongP@55w0rd
MURA_ADMINEMAIL: youremail@domain.com
MURA_APPRELOADKEY: appreload
MURA_DATASOURCE: dsn_mura
MURA_DATABASE: muradb
MURA_DBTYPE: mysql
MURA_DBUSERNAME: root
MURA_DBPASSWORD: 5trongP@55w0rd
MURA_DBHOST: svc_muradb
MURA_DBPORT: 3306
MURA_SITEIDINURLS: "false"
MURA_INDEXFILEINURLS: "true"
MURA_TESTBOX: "true"
MURA_USESSL: "false"
volumes:
- vol_mura_modules:/var/www/modules
- vol_mura_plugins:/var/www/plugins
- vol_mura_sites:/var/www/sites
- vol_mura_themes:/var/www/themes
ports:
- "8888:8888"
# DB
svc_muradb:
image: mysql:5.7.19
environment:
MYSQL_DATABASE: muradb
MYSQL_ROOT_PASSWORD: 5trongP@55w0rd
volumes:
- vol_muradb:/var/lib/mysql
ports:
- "5555:3306"
# Mounts
volumes:
vol_muradb:
vol_mura_modules:
vol_mura_plugins:
vol_mura_sites:
vol_mura_themes:
Please submit issues to https://github.com/blueriver/docker-muracms/issues.
Apache License, Version 2.0