Director 4.0 is a website management and hosting platform (based on the former Director platform) that is designed to scale. It replaces the former Director platform which has problems with performance, scalability, and ease of use.
It is composed of three primary components:
orchestrator
: The code that orchestrates the Docker containersmanager
: The public-facing Django web application that provides an easy-to-use interface for managing websites.router
: The code that runs on the balancers and handles a lot of the frontend for custom domains.A full description of the project's architecture can be found in docs/ARCHITECTURE.md.
Each of the three components has specific Python dependencies described in each Pipfile
.
We recommend that you have a server for each component to replicate an actual production environment.
The resources (storage, memory, CPU, and network) required to run Director 4.0 depend on the number of sites being run, user load, request count, and other factors.
We use Vagrant for providing a partial replica of a production environment. See docs/SETUP.md for details.
This code is released under the MIT License as described in LICENSE.
The authors of Director 4.0 would like to acknowledge the contributors to the TJHSST Director application for providing inspiration for this project.
The authors of Director 4.0 would also like to acknowledge the support of the TJHSST Computer Systems Lab, especially research advisor Dr. Patrick White for his guidance and mentoring.