Get up and running quickly with Open edX services.
Documentation is on Read the Docs. Code repository is on GitHub.
This project replaces the older Vagrant-based devstack with a multi-container approach driven by Docker Compose.
A Devstack installation includes the following Open edX components by default:
- The Learning Management System (LMS)
- Open Response Assessments (ORA2), among other LMS plug-ins.
- Open edX Studio
- Discussion Forums
- E-Commerce
- Credentials
- Notes
- Course Discovery
- Open edX Search
- A demonstration Open edX course
- The Publisher and Gradebook micro-frontends
It also includes the following extra components:
- XQueue
- The Learning micro-frontend (A.K.A the new Courseware experience)
- The Program Console micro-frontend
- The Library Authoring micro-frontend
- edX Registrar service.
- The course-authoring micro-frontend
- Where to Find Help
- Notices
- Prerequisites
- Roadmap
- Getting Started
- Usernames and Passwords
- Service List
- Useful Commands
- Known Issues
- Advanced Configuration Options
There are a number of places to get help, including mailing lists and real-time chat. Please choose an appropriate venue for your question. This helps ensure that you get good prompt advice, and keeps discussion focused. For details of your options, see the Community pages.
- See the most common development workflow (after you've finished Getting Started).
- See some helpful troubleshooting tips.
- See the Frequently Asked Questions.
- Or learn about testing and debugging your code in devstack.
You can also browse all the documentation in Read the Docs.
NOTE: LMS is now using MySql 5.7 by default. You have to run make dev.pull.lms
and make dev.provision.lms
(more details in Getting Started) to fetch latest images and reprovision local copies of databases in order for an existing devstack setup to keep working.
You will need to have the following installed:
- make
- Python 3
- Docker
This project requires Docker 17.06+ CE. We recommend Docker Stable, but Docker Edge should work as well.
NOTE: Switching between Docker Stable and Docker Edge will remove all images and settings. Don't forget to restore your memory setting and be prepared to provision.
For macOS users, please use Docker for Mac. Previous Mac-based tools (e.g. boot2docker) are not supported.
Since a Docker-based devstack runs many containers, you should configure Docker with a sufficient amount of resources. We find that configuring Docker for Mac with a minimum of 2 CPUs, 8GB of memory, and a disk image size of 96GB does work.
Docker for Windows may work but has not been tested and is not supported.
If you are using Linux, use the overlay2
storage driver, kernel version
4.0+ and not overlay
. To check which storage driver your
docker-daemon
uses, run the following command.
docker info | grep -i 'storage driver'
You should run all make
commands described below on your local machinge, not
from within a Virtual Machine, as these commands are meant to stand up a VM-like environment using
Docker containers.
However, you may want to run the make
commands from within a Python 3 virtual
environment, as described in Getting Started. This will keep the Python packages required for Devstack separate from
the ones installed globally on your system.
This repository is in sustained status. The goal is to deprecate this codebase and move the development environment setup into the repos with the application code.
Documentation for future of devstack can be found at: decentralized devstack
Documentation for first prototype of decentralized devstack can be found at: decentralized devstack workflows
The default devstack services can be run by following the steps below.
Install the requirements inside of a Python virtualenv.
make requirements
This will install docker-compose and other utilities into your virtualenv.
The Docker Compose file mounts a host volume for each service's executing code. The host directory defaults to be a sibling of this directory. For example, if this repo is cloned to
~/workspace/devstack
, host volumes will be expected in~/workspace/course-discovery
,~/workspace/ecommerce
, etc. These repos can be cloned with the command below.make dev.clone # or, `make dev.clone.https` if you don't have SSH keys set up.
You may customize where the local repositories are found by setting the
DEVSTACK_WORKSPACE
environment variable.(macOS only) Share the cloned service directories in Docker, using Docker -> Preferences -> File Sharing in the Docker menu.
Pull any changes made to the various images on which the devstack depends.
make dev.pull
- Optional: You have an option to use NFS on MacOS which may improve the performance significantly. To set it up ONLY ON MAC, do
make dev.nfs.setup
Run the provision command, if you haven't already, to configure the various services with superusers (for development without the auth service) and tenants (for multi-tenancy).
NOTE: When running the provision command, databases for ecommerce and edxapp will be dropped and recreated.
The username and password for the superusers are both
edx
. You can access the services directly via Django admin at the/admin/
path, or login via single sign-on at/login/
.Default:
make dev.provision
Provision using docker-sync:
make dev.sync.provision
Provision using NFS:
make dev.nfs.provision
This is expected to take a while, produce a lot of output from a bunch of steps, and finally end with
Provisioning complete!
NOTE: This command will bring up both MySQL 5.6 and 5.7 databases until all services are upgraded to 5.7.
Start the services. This command will mount the repositories under the
DEVSTACK_WORKSPACE
directory.NOTE: it may take up to 60 seconds for the LMS to start, even after the
make dev.up
command outputsdone
.Default:
make dev.up
Start using docker-sync:
make dev.sync.up
Start using NFS:
make dev.nfs.up
To stop a service, use make dev.stop.<service>
, and to both stop it
and remove the container (along with any changes you have made
to the filesystem in the container) use make dev.down.<service>
.
After the services have started, if you need shell access to one of the
services, run make dev.shell.<service>
. For example to access the
Catalog/Course Discovery Service, you can run:
make dev.shell.discovery
To see logs from containers running in detached mode, you can either use "Kitematic" (available from the "Docker for Mac" menu), or by running the following:
make dev.logs
To view the logs of a specific service container run make dev.logs.<service>
.
For example, to access the logs for Ecommerce, you can run:
make dev.logs.ecommerce
For information on the supported make
commands, you can run:
make help
Now that you're up and running, read about the most common development workflow.
The provisioning script creates a Django superuser for every service.
Email: edx@example.com Username: edx Password: edx
The LMS also includes demo accounts. The passwords for each of these accounts
is edx
.
Account Description staff@example.com
An LMS and Studio user with course creation and editing permissions. This user is a course team member with the Admin role, which gives rights to work with the demonstration course in Studio, the LMS, and Insights. verified@example.com
A student account that you can use to access the LMS for testing verified certificates. audit@example.com
A student account that you can use to access the LMS for testing course auditing. honor@example.com
A student account that you can use to access the LMS for testing honor code certificates.
These are the edX services that Devstack can provision, pull, run, attach to, etc.
Each service is accessible at localhost
on a specific port.
The table below provides links to the homepage, API root, or API docs of each service,
as well as links to the repository where each service's code lives.
The services marked as Default
are provisioned/pulled/run whenever you run
make dev.provision
/ make dev.pull
/ make dev.up
, respectively.
The extra services are provisioned/pulled/run when specifically requested (e.g.,
make dev.provision.xqueue
/ make dev.pull.xqueue
/ make dev.up.xqueue
).
Alternatively, you can run these by modifying the DEFAULT_SERVICES
option as described in the Advanced Configuration Options section.
Service | URL | Type | Role |
---|---|---|---|
lms | http://localhost:18000/ | Python/Django | Default |
studio | http://localhost:18010/ | Python/Django | Default |
forum | http://localhost:44567/api/v1/ | Ruby/Sinatra | Default |
discovery | http://localhost:18381/api-docs/ | Python/Django | Default |
ecommerce | http://localhost:18130/dashboard/ | Python/Django | Default |
credentials | http://localhost:18150/api/v2/ | Python/Django | Default |
edx_notes_api | http://localhost:18120/api/v1/ | Python/Django | Default |
frontend-app-publisher | http://localhost:18400/ | MFE (React.js) | Default |
gradebook | http://localhost:1994/ | MFE (React.js) | Default |
registrar | http://localhost:18734/api-docs/ | Python/Django | Extra |
program-console | http://localhost:1976/ | MFE (React.js) | Extra |
frontend-app-learning | http://localhost:2000/ | MFE (React.js) | Extra |
frontend-app-library-authoring | http://localhost:3001/ | MFE (React.js) | Extra |
course-authoring | http://localhost:2001/ | MFE (React.js) | Extra |
xqueue | http://localhost:18040/api/v1/ | Python/Django | Extra |
You may notice that many Devstack commands come in the form dev.ACTION.SERVICE
.
As examples:
make dev.up.registrar
make dev.shell.lms
make dev.attach.studio
make dev.down.credentials
make dev.migrate.edx_notes_api
make dev.static.ecommerce
make dev.restart-devserver.forum
make dev.logs.gradebook
In general, these commands can also be given in the form SERVICE-ACTION
,
which saves some keystrokes and is often more friendly for automatic command-completion
by hitting TAB. As examples:
make registrar-up
make lms-shell
make studio-attach
make credentials-down
make edx_notes_api-migrate
make ecommerce-static
make forum-restart-devserver
make gradebook-logs
make dev.up
can take a long time, as it starts all services, whether or not
you need them. To instead only start a single service and its dependencies, run
make dev.up.<services>
. For example:
make dev.up.lms
That above command will bring up LMS (along with Memcached, MySQL, DevPI, et al), but it will not bring up Credentials, Studio, or E-Commerce or any of the other default services.
You can also specify multiple services:
make dev.up.ecommerce+studio
Similarly, make dev.pull
can take a long time, as it pulls all services' images,
whether or not you need them.
To instead only pull images required by your service and its dependencies,
run make dev.pull.<services>
. For example:
make dev.pull.discovery
Sometimes you may need to manually restart a particular application server To do so,
the quickest command to run is make dev.restart-devserver.<service>
, which restarts the Django/Sinatra server inside the container without restarting the container itself. For example:
make dev.restart-devserver.credentials
This can be helpful, for example, if automatic code reloading isn't working for some reason.
If you wish to restart the container itself, which takes a bit longer but may resolve a larger class of issues, use make dev.restart-container.<services>
. For example:
make dev.restart-container.credentials
Currently, some containers rely on Elasticsearch 7 and some rely on Elasticsearch 1.5. This is because services are in the process of being upgraded to Elasticsearch 7, but not all of them support Elasticsearch 7 yet. As we complete these migrations, we will update the dependencies of these containers.
The file options.mk
sets several configuration options to default values.
For example DEVSTACK_WORKSPACE
(the folder where your Git repos are expected to be)
is set to this directory's parent directory by default,
and DEFAULT_SERVICES
(the list of services that are provisioned and run by default)
is set to a fairly long list of services out of the box.
For more detail, refer to the comments in the file itself.
If you're feeling brave, you can create an git-ignored overrides file called
options.local.mk
in the same directory and set your own values. In general,
it's good to bring down containers before changing any settings.
The COMPOSE_PROJECT_NAME
variable is used to define Docker namespaced volumes
and network based on this value, so changing it will give you a separate set of databases.
This is handled for you automatically by setting the OPENEDX_RELEASE
environment variable in options.mk
(e.g. COMPOSE_PROJECT_NAME=devstack-juniper.master
. Should you want to manually override this, edit the options.local.mk
in the root of this repo and create the file if it does not exist. Change the devstack project name by adding the following line:
# Example: COMPOSE_PROJECT_NAME=secondarydevstack COMPOSE_PROJECT_NAME=<your-alternate-devstack-name>
As a specific example, if OPENEDX_RELEASE
is set in your environment as juniper.master
, then COMPOSE_PROJECT_NAME
will default to devstack-juniper.master
instead of devstack
.