2016-11-30 23:27:20 +00:00
# containerd roadmap
This is a high level roadmap for the project that outlines what is currently being worked on, what comes next, and where you can help.
The following are the different status the various phases of development can be in:
* Not Started - no work or thinking has been done towards the goal
* In Design - design work has started for the component and you can find design documents in the `design` folder
* In Progress - design has mostly finished and development has started
* Completed - the development work has been completed
* Stable - the apis for the phase are feature complete and considered stable
## Phase 1
2016-12-01 20:00:06 +00:00
**Status:** In Progress
2016-11-30 23:27:20 +00:00
### GRPC API
2016-12-01 20:00:06 +00:00
**Documents:**
2016-11-30 23:27:20 +00:00
We are going from a top down design for filling out this missing pieces of containerd and design of the API.
### Design
2016-12-01 20:00:06 +00:00
**Documents:**
2016-11-30 23:27:20 +00:00
The high level design work is needed so that the architecture of containerd stays consistent throughout the development process.
### Build & Test Process
2016-12-01 20:00:06 +00:00
**Documents:**
2016-11-30 23:27:20 +00:00
We need to have a simple build and test process for new developers to bootstrap their environments.
Because containerd will be the base of many high level systems we need to have a simple build process that does
not require high level tooling.
## Phase 2
Phase 2 includes most of the design and development work for the execution and storage layers of containerd.
It will include porting over existing "graph drivers" from Docker Engine and finding a common model for representing snapshots for layered filesystems.
This will also include moving the existing execution code support OCI's Runtime Spec and the existing containerd execution code.
2016-12-01 20:00:06 +00:00
**Status:** In Design
2016-11-30 23:27:20 +00:00
### Execution
2016-12-01 20:00:06 +00:00
The execution layer is responsible for the create of containers and the management and supervision of processes.
2016-11-30 23:27:20 +00:00
### Storage
2016-12-01 20:00:06 +00:00
**Documents:** https://github.com/docker/containerkit/blob/master/design/snapshots.md
2016-11-30 23:27:20 +00:00
## Phase 3
Phase 3 involves porting the network drivers from libnetwork and finding a good middle ground between the abstractions of libnetwork and the CNI spec.
This also includes getting support for the OCI Image spec built into containerd.
2016-12-01 20:00:06 +00:00
**Status:** Not Started
2016-11-30 23:27:20 +00:00
### Distribution
### Networking
2016-12-01 20:00:06 +00:00
The networking component will allow the management of network namespaces and interface creation and attachment to namespaces.
2016-11-30 23:27:20 +00:00
## Phase 4
Phase 4 includes work on helping with the releases and packaging of containerd for various distros.
2016-12-01 20:00:06 +00:00
**Status:** Not Started
2016-11-30 23:27:20 +00:00
### Release Process & Tools