Add dev report for 2-10-2017
Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
This commit is contained in:
parent
89f62d4fae
commit
a0fd5036c3
1 changed files with 71 additions and 0 deletions
71
reports/2017-01-10.md
Normal file
71
reports/2017-01-10.md
Normal file
|
@ -0,0 +1,71 @@
|
|||
# Development Report for Feb 10, 2017
|
||||
|
||||
Sorry for slacking off last week on the report. We totally spaced it.
|
||||
This week we will go over what happened last week and this week.
|
||||
|
||||
## Snapshot Design Changes
|
||||
|
||||
* https://github.com/docker/containerd/pull/496
|
||||
|
||||
After receiving feedback on the `snapshot.Driver` interface, now known as the
|
||||
`Snapshotter`, it was found that the behavior of active and committed snapshots
|
||||
was confusing. Specifically, it was hard to tell which methods to use based on
|
||||
the state of the snapshot. It was also confusing which identifier to use based
|
||||
on the state.
|
||||
|
||||
To clean this up, we moved to using "Active" and "Committed" as the type of a
|
||||
snapshot, as opposed to the state of the snapshot. These lifecycle
|
||||
relationships are such that "Active" snapshots can only be created from a
|
||||
"Committed" snapshot and "Committed" snapshots must come from an "Active"
|
||||
snapshot. We retain the concept of a parent for "Active" and "Committed"
|
||||
snapshots, but clarified that only "Committed" snapshots can be a parent.
|
||||
|
||||
|
||||
As part of this, we unified the keyspace of snapshots. For common operations,
|
||||
such as removal and stat, we only have a single method that works for both
|
||||
active and committed snapshots. For methods that take one or the other, the
|
||||
restriction is called out. `Remove` and `Delete` were consolidated as part of
|
||||
this. This also makes it easier to handle scenarios that use the snapshot
|
||||
identity as a lock to coordinate multiple writers.
|
||||
|
||||
`Exists` and `Parent` have also be consolidated into single `Stat` call. This
|
||||
returns an `Info` structure which includes information about state and
|
||||
parentage. We also simplify the `Walk` method as part of this.
|
||||
|
||||
Effectively, we now have snapshots that are either active or committed and a
|
||||
much smaller interface!
|
||||
|
||||
## Bundles Bundles Bundles
|
||||
|
||||
We spend time talking with people implementing Windows support as well as a few other users.
|
||||
One the the major issues with our current approach was that bundles were a central part of our architecture.
|
||||
The content and storage subsystems would produce bundles and the execution subsystem would consume them.
|
||||
However, with a bundle being on the filesystem, having this concept does not work as smoothly on Windows
|
||||
as it would for Unix platforms.
|
||||
|
||||
So the major design change is that bundles will be an implemenation detail of the runtime and not a core
|
||||
part of the API. You will no longer pass the bundle path to containerd, it will manage bundles internally
|
||||
and the root filesystem mounts along with the spec, passed via the `Any` type, will be API fields for the
|
||||
create request of a container.
|
||||
|
||||
## Runtimes
|
||||
|
||||
With the bundles change above we also need to make sure changes for where containers are created and who
|
||||
does the supervision after creation.
|
||||
|
||||
The runtimes in containerd, things such as Linux, Windows, and Solaris, will be responsible for the
|
||||
creation of containers and loading of containers when containerd boots.
|
||||
|
||||
The containerd core will be responsible for interfacing with the GRPC API and managing a common `Container`
|
||||
interface that the runtimes produce. The supervision of containers will be handled in the core.
|
||||
This is not much of a change from today, just refining where responsibilities lie.
|
||||
|
||||
## Progress and POC
|
||||
|
||||
Overall design has been a large focus for us at the moment. While containerd can run containers today it
|
||||
is not optimized in terms of speed or design. With the work we did this week to make sure that containerd
|
||||
will work across many different platforms with first class support, not as an after thought, we are in a good
|
||||
position to really start on the development work and get a POC out within the next few weeks.
|
||||
|
||||
This POC should give you a good idea of what containerd can do, its APIs, and how users will interact with
|
||||
its various subsystems.
|
Loading…
Reference in a new issue