2015-10-23 02:59:31 +08:00
# OCI Specs Roadmap
This document serves to provide a long term roadmap on our quest to a 1.0 version of the OCI container specification.
Its goal is to help both maintainers and contributors find meaningful tasks to focus on and create a low noise environment.
The items in the 1.0 roadmap can be broken down into smaller milestones that are easy to accomplish.
The topics below are broad and small working groups will be needed for each to define scope and requirements or if the feature is required at all for the OCI level.
Topics listed in the roadmap do not mean that they will be implemented or added but are areas that need discussion to see if they fit in to the goals of the OCI.
2016-04-05 02:14:04 +08:00
Listed topics may defer to the [project wiki ](https://github.com/opencontainers/runtime-spec/wiki/RoadMap: ) for collaboration.
2015-12-17 05:37:50 +08:00
2015-10-23 02:59:31 +08:00
## 1.0
### Digest and Hashing
2015-11-17 20:23:40 +08:00
A bundle is designed to be moved between hosts.
2015-10-23 02:59:31 +08:00
Although OCI doesn't define a transport method we should have a cryptographic digest of the on-disk bundle that can be used to verify that a bundle is not corrupted and in an expected configuration.
*Owner:* philips
### Define Container Lifecycle
2015-11-17 20:23:40 +08:00
Containers have a lifecycle and being able to identify and document the lifecycle of a container is very helpful for implementations of the spec.
2015-10-23 02:59:31 +08:00
The lifecycle events of a container also help identify areas to implement hooks that are portable across various implementations and platforms.
*Owner:* mrunalp
2016-01-14 03:20:41 +08:00
### Define Standard Container Actions (Target release: v0.3.0)
2015-10-23 02:59:31 +08:00
Define what type of actions a runtime can perform on a container without imposing hardships on authors of platforms that do not support advanced options.
2016-01-14 03:20:41 +08:00
*Owner:* duglin
2015-10-23 02:59:31 +08:00
### Container Definition
Define what a software container is and its attributes in a cross platform way.
2016-01-14 03:20:41 +08:00
Could be solved by lifecycle/ops and create/start split discussions
*Owner:* vishh & duglin
2015-10-23 02:59:31 +08:00
### Live Container Updates
2015-11-17 20:23:40 +08:00
Should we allow dynamic container updates to runtime options?
2015-10-23 02:59:31 +08:00
2016-01-14 03:20:41 +08:00
Proposal: make it an optional feature
*Owner:* hqhq (was vishh) robdolinms, bcorrie
2015-10-23 02:59:31 +08:00
2016-01-14 03:20:41 +08:00
### Validation Tooling (Target release: v0.3.0)
2015-10-23 02:59:31 +08:00
2015-11-17 20:23:40 +08:00
Provide validation tooling for compliance with OCI spec and runtime environment.
2015-10-23 02:59:31 +08:00
*Owner:* mrunalp
2015-11-12 04:12:09 +08:00
### Testing Framework
Provide a testing framework for compliance with OCI spec and runtime environment.
*Owner:* liangchenye
2015-10-23 02:59:31 +08:00
### Version Schema
Decide on a robust versioning schema for the spec as it evolves.
2016-01-14 03:20:41 +08:00
Resolved but release process could evolve. Resolved for v0.2.0, expect to revisit near v1.0.0
*Owner:* vbatts
2015-10-23 02:59:31 +08:00
### Printable/Compiled Spec
2015-12-04 12:39:34 +08:00
Regardless of how the spec is written, ensure that it is easy to read and follow for first time users.
2015-10-23 02:59:31 +08:00
2016-01-14 03:20:41 +08:00
Part of this is resolved. Produces an html & pdf.
Done
Would be nice to publish to the OCI web site as part of our release process.
2015-11-17 20:23:40 +08:00
*Owner:* vbatts
2015-10-23 02:59:31 +08:00
### Base Config Compatibility
Ensure that the base configuration format is viable for various platforms.
2015-11-17 20:23:40 +08:00
Systems:
2015-10-23 02:59:31 +08:00
* Solaris
2015-11-17 20:23:40 +08:00
* Windows
2015-10-23 02:59:31 +08:00
* Linux
2016-01-14 03:20:41 +08:00
*Owner:* robdolinms as lead coordinator
2015-10-23 02:59:31 +08:00
### Full Lifecycle Hooks
2016-01-14 03:40:03 +08:00
2015-10-23 02:59:31 +08:00
Ensure that we have lifecycle hooks in the correct places with full coverage over the container lifecycle.
2016-01-14 03:20:41 +08:00
Will probably go away with Vish's work on splitting create and start, and if we have exec.
2015-11-17 20:23:40 +08:00
*Owner:*
2016-01-14 03:40:03 +08:00
### Distributable Format
A common format for serializing and distributing bundles.
*Owner:* vbatts