openHPI / poseidon

Scalable task execution orchestrator for CodeOcean
MIT License
7 stars 2 forks source link

Poseidon

CI codecov

Poseidon logo

Poseidon provides containerized execution of arbitrary user code inside a Docker container for learning purposes. It has two main purposes:

  1. Securing the executions so that they are isolated from each other and from the host system.
  2. Being scalable enough to provide hundreds of executions per minute.

Poseidon also offers a live I/O connection to the running program via WebSocket.

Poseidon as mediator between CodeOcean and Nomad.

Poseidon is designed to be used with CodeOcean, a code-execution provider and auto-grader used in MOOC platforms.

Poseidon requires a Nomad cluster for scheduling its executions, which needs to be set up separately.

Documentation

For the OpenAPI 3.0 definition of the API Poseidon provides, see the swagger.yaml.

For the rest of the documentation see the docs folder. It describes...

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/openHPI/poseidon. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.

License

Poseidon is available as open source under the terms of the MIT License.

Code of Conduct

Everyone interacting in this project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.