Public | Automated Build

Last pushed: 8 days ago
Short Description
Includes latest Ubuntu 16.04, PHP7, and Moodle 3.x. Build hooks for ubuntu/xenial and moodle stable.
Full Description

docker-moodle

A Dockerfile that installs and runs the latest Moodle 3.3 stable, with external MySQL Database.

Tags:

  • latest - 3.3 stable
  • v3.2 - 3.2 stable
  • v3.1 - 3.1 stable

Installation

git clone https://github.com/jmhardison/docker-moodle
cd docker-moodle
docker build -t moodle .

Usage

Test Environment

When running locally or for a test deployment, use of localhost is acceptable.

To spawn a new instance of Moodle:

docker run -d --name DB -p 3306:3306 -e MYSQL_DATABASE=moodle -e MYSQL_ROOT_PASSWORD=moodle -e MYSQL_USER=moodle -e MYSQL_PASSWORD=moodle mysql
docker run -d -P --name moodle --link DB:DB -e MOODLE_URL=http://localhost:8080 -p 8080:80 jhardison/moodle

You can visit the following URL in a browser to get started:

http://localhost:8080

Production Deployment

For a production deployment of moodle, use of a FQDN is advised. This FQDN should be created in DNS for resolution to your host. For example, if your internal DNS is company.com, you could leverage moodle.company.com and have that record resolve to the host running your moodle container. The moodle url would then be, MOODLE_URL=http://moodle.company.com
In the following steps, replace MOODLE_URL with your appropriate FQDN.

  • Deploy With Docker

    docker run -d --name DB -p 3306:3306 -e MYSQL_DATABASE=moodle -e MYSQL_ROOT_PASSWORD=moodle -e MYSQL_USER=moodle -e MYSQL_PASSWORD=moodle mysql
    docker run -d -P --name moodle --link DB:DB -e MOODLE_URL=http://moodle.company.com -p 80:80 jhardison/moodle
    
  • Deploy with Docker Compose

Pull the latest source from GitHub:

git clone https://github.com/jmhardison/docker-moodle.git

Update the moodle_variables.env file with your information. Please note that we are using v3 compose files, as a stop gap link env variable are manually filled since v3 no longer automatically fills those for use.

Once the environment file is filled in you may bring up the service with:
docker-compose up -d

Caveats

The following aren't handled, considered, or need work:

  • moodle cronjob (should be called from cron container)
  • log handling (stdout?)
  • email (does it even send?)

Credits

This is a fork of Jon Auer's Dockerfile.
This is a reductionist take on sergiogomez's docker-moodle Dockerfile.

Docker Pull Command
Owner
jhardison
Source Repository

Comments (4)
jhardison
a month ago

@divneet you can do that several ways. probably the fastest dirtiest is to exec into the container and drop to bash. (docker exec -it contianername /bin/bash)

You can also copy files using the docker cp command to and from the container.

divneet
2 months ago

hello , is there way to edit the php.ini file ? Was looking to increase the upload limit .
thanks

tobiashochguertel
5 months ago

Thanks for forking the work and keep it maintained!

santyabreu
7 months ago

Hello!!! Thank you for this amazing distro. But I have problem. I'm trying to add the ldap php extension with no sucess. Any procedure for this?

I've tried with php7.0-ldap and php-ldap. The build shows that are installed remaking the container it does not appear from working.

Please help