Get up and running quickly with edX services.
If you are seeking info on the Vagrant-based devstack, please see https://openedx.atlassian.net/wiki/display/OpenOPS/Running+Devstack. This project is meant to replace the traditional Vagrant-based devstack with a multi-container approach driven by Docker Compose. It is still in the alpha/beta testing phase. Support for this project is limited at the moment, so it may take a while to respond to issues.
You should run any Make targets described below on your local machine, not from within a VM.
This project was developed and tested using Docker 1.13+. If you are using OS X, please use Docker for Mac. Previous Mac-based tools (e.g. boot2docker) are not supported.
Docker for Windows may work but has not been tested and is not supported.
All of the services can be run by following the steps below. Note that since we are running many containers, you should configure Docker with a sufficient amount of resources. Our testing found that configuring Docker for Mac with 2 CPUs and 4GB of memory works well.
- Create a Python 3
virtualenv
. If you're using virtualenvwrapper, you can do this with:
$ mkvirtualenv devstack --python=$(which python3)
Source the virtualenv and install requirements:
$ workon devstack
(devstack)$ make requirements
- The Docker Compose file mounts a host volume for each service's executing code. The host directory is expected 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.
(devstack)$ make clone
-
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).
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/
.(devstack)$ make devstack.provision
-
Start the services.
(devstack)$ make devstack.start
After the services have started, if you need shell access to one of the services, run make devstack.open.<service>
.
For example to access the Catalog/Course Discovery Service, you can run:
(devstack)$ make devstack.open.discovery
The provisioning script creates a Django superuser for every service.
Email: [email protected]
Username: edx
Password: edx
The LMS also includes demo accounts. The passwords for each of these accounts is edx
.
Username | |
---|---|
audit | [email protected] |
honor | [email protected] |
staff | [email protected] |
verified | [email protected] |
Each service is accessible at localhost
on a specific port. The table below provides links to the homepage of each
service. Since some services are not meant to be user-facing, the "homepage" may be the API root.
Service | URL |
---|---|
Credentials | http://localhost:18150/api/v2/ |
Catalog/Discovery | http://localhost:18381/api-docs/ |
E-Commerce/Otto | http://localhost:18130/dashboard/ |
LMS | http://localhost:18000/ |
Programs | http://localhost:18140/api/v1/ |
Studio/CMS | http://localhost:18010/ |
There is still work to be done before this is ready for full release to the Open edX community. Here are the major items:
- Align with OEP-5
- Finish provisioning all services
- Load demo data
- PyCharm debugging
- Merge devstack settings for edxapp (https://github.com/edx/edx-platform/pull/14376), and reactivate host volume