The Moby Project - a collaborative project for the container ecosystem to assemble container-based systems
Find a file
Laura Brehm a34060cdb4
Resolve and store manifest when creating container
This addresses the previous issue with the containerd store where, after a container is created, we can't deterministically resolve which image variant was used to run it (since we also don't store what platform the image was fetched for).

This is required for things like `docker commit`, and computing the containers layer size later, since we need to resolve the specific image variant.

Signed-off-by: Laura Brehm <laurabrehm@hey.com>
2023-03-06 15:13:36 +01:00
.github Upgrade to Go 1.20.1 2023-02-22 16:38:01 -05:00
api Merge pull request #45032 from corhere/shim-opts 2023-03-02 21:45:05 +01:00
builder builder: Remove buildkit's build information 2023-03-02 19:17:11 +01:00
cli cli: remove cli/config package, integrate into cmd/dockerd 2022-12-14 12:52:40 +01:00
client Merge pull request #44739 from nicks/nicks/invalid-character 2023-01-26 15:22:08 -08:00
cmd Merge pull request #43197 from dajudge/default-bridge-mtu 2023-03-02 20:21:47 +01:00
container Resolve and store manifest when creating container 2023-03-06 15:13:36 +01:00
contrib contrib/apparmor: remove version-conditionals (< 2.9) from template 2023-02-08 18:05:02 +01:00
daemon Resolve and store manifest when creating container 2023-03-06 15:13:36 +01:00
distribution Merge pull request #45050 from lmbarros/close-reader 2023-02-21 22:57:53 +00:00
dockerversion IAmStatic not used anymore 2023-01-01 18:03:02 +01:00
docs api: Remove <none> in Repo(Tags|Digests) for >= 1.43 2023-02-27 19:44:43 +01:00
errdefs errdefs: FromStatusCode() don't log "FIXME" debug message 2022-12-20 16:03:46 +01:00
hack Upgrade to Go 1.20 2023-02-22 16:37:59 -05:00
image docs: fix JSON format error 2023-02-03 08:16:48 +00:00
integration Make default options for newly created networks configurable 2023-03-01 07:58:26 +01:00
integration-cli integration-cli: Fix hanging TestLogsFollowGoroutines* 2023-01-05 18:10:32 +01:00
internal Add reusable chroot and unshare utilities 2022-10-26 12:06:31 -04:00
layer use errors.Is() to handle image store errors 2023-01-02 09:41:50 +01:00
libcontainerd Merge pull request #45032 from corhere/shim-opts 2023-03-02 21:45:05 +01:00
libnetwork libnet/ipam: use netip types internally 2023-02-23 18:10:01 -05:00
oci Merge pull request #44275 from thaJeztah/move_pkg_system_funcs 2022-12-16 15:25:41 +01:00
opts Make default options for newly created networks configurable 2023-03-01 07:58:26 +01:00
pkg Migrate away from things deprecated in Go 1.20 2023-02-15 12:30:32 -05:00
plugin Merge pull request #45032 from corhere/shim-opts 2023-03-02 21:45:05 +01:00
profiles profiles/apparmor: remove version-conditional constraints (< 2.8.96) 2023-02-08 18:04:04 +01:00
project graphdriver/btrfs: needs kernel headers >= 4.12, not >= 4.7 2023-01-08 05:04:47 +09:00
quota gofmt GoDoc comments with go1.19 2022-07-08 19:56:23 +02:00
reference remove unneeded "digest" alias for "go-digest" 2022-03-04 14:49:42 +01:00
registry registry: acquire mutex in IsInsecureRegistry 2023-02-28 19:42:49 -05:00
reports Fix typos 2018-05-16 09:15:43 +08:00
restartmanager restartmanager: remove RestartManager interface 2022-12-28 09:36:58 +01:00
runconfig hostconfig: move unit tests to api/types/container 2022-12-27 22:31:37 +01:00
testutil api: Remove <none> in Repo(Tags|Digests) for >= 1.43 2023-02-27 19:44:43 +01:00
vendor Merge pull request #45032 from corhere/shim-opts 2023-03-02 21:45:05 +01:00
volume Use GetBoolOrDefault to remove duplicated invalidFilter usages 2023-01-26 16:28:53 +01:00
.dockerignore ignorefiles: cleanup 2022-11-21 18:43:42 -07:00
.gitattributes chore: fix linguist for Dockerfile 2022-04-27 06:38:41 +02:00
.gitignore hack: introduce validate/no-module 2022-12-12 18:39:06 -07:00
.mailmap .mailmap: cleanup and additions 2022-11-30 12:05:31 +01:00
AUTHORS AUTHORS: regenerate 2023-02-22 00:36:57 -07:00
codecov.yml codecov: disable "patch" status 2022-06-07 17:24:46 +02:00
CONTRIBUTING.md CONTRIBUTING.md: drop reference to the Derek GitHub bot 2023-01-10 15:42:09 -07:00
docker-bake.hcl Dockerfile: smoke tests for static builds 2023-01-18 18:46:53 +01:00
Dockerfile Upgrade to Go 1.20.1 2023-02-22 16:38:01 -05:00
Dockerfile.e2e Upgrade to Go 1.20.1 2023-02-22 16:38:01 -05:00
Dockerfile.simple Upgrade to Go 1.20.1 2023-02-22 16:38:01 -05:00
Dockerfile.windows Upgrade to Go 1.20.1 2023-02-22 16:38:01 -05:00
Jenkinsfile Jenkinsfile: Fix dev image build fox ppc64le/s390x archs 2022-11-29 11:59:09 +01:00
LICENSE Update LICENSE 2018-09-12 14:27:53 +01:00
MAINTAINERS add new maintainers! 2023-02-14 10:03:34 +00:00
Makefile Dockerfile: rename dev stages 2023-01-01 18:03:03 +01:00
NOTICE switch kr/pty to creack/pty v1.1.7 2019-07-29 16:59:08 -07:00
README.md Fix grammar in README.md 2022-11-10 19:49:41 +00:00
ROADMAP.md Fix some typos in ROADMAP.md 2019-01-25 14:27:13 +08:00
SECURITY.md Update SECURITY.md to have an option to keep name anonymous if requested. 2019-06-18 16:37:16 +00:00
TESTING.md TESTING.md: note that integration-cli is deprecated 2020-12-18 07:51:46 +01:00
vendor.mod vendor: github.com/containerd/containerd v1.6.19 2023-02-28 23:27:11 +01:00
vendor.sum vendor: github.com/containerd/containerd v1.6.19 2023-02-28 23:27:11 +01:00
VENDORING.md fix the bare url and the Summary of http://semver.org 2017-01-17 16:20:11 +08:00

The Moby Project

Moby Project logo

Moby is an open-source project created by Docker to enable and accelerate software containerization.

It provides a "Lego set" of toolkit components, the framework for assembling them into custom container-based systems, and a place for all container enthusiasts and professionals to experiment and exchange ideas. Components include container build tools, a container registry, orchestration tools, a runtime and more, and these can be used as building blocks in conjunction with other tools and projects.

Principles

Moby is an open project guided by strong principles, aiming to be modular, flexible and without too strong an opinion on user experience. It is open to the community to help set its direction.

  • Modular: the project includes lots of components that have well-defined functions and APIs that work together.
  • Batteries included but swappable: Moby includes enough components to build fully featured container systems, but its modular architecture ensures that most of the components can be swapped by different implementations.
  • Usable security: Moby provides secure defaults without compromising usability.
  • Developer focused: The APIs are intended to be functional and useful to build powerful tools. They are not necessarily intended as end user tools but as components aimed at developers. Documentation and UX is aimed at developers not end users.

Audience

The Moby Project is intended for engineers, integrators and enthusiasts looking to modify, hack, fix, experiment, invent and build systems based on containers. It is not for people looking for a commercially supported system, but for people who want to work and learn with open source code.

Relationship with Docker

The components and tools in the Moby Project are initially the open source components that Docker and the community have built for the Docker Project. New projects can be added if they fit with the community goals. Docker is committed to using Moby as the upstream for the Docker Product. However, other projects are also encouraged to use Moby as an upstream, and to reuse the components in diverse ways, and all these uses will be treated in the same way. External maintainers and contributors are welcomed.

The Moby project is not intended as a location for support or feature requests for Docker products, but as a place for contributors to work on open source code, fix bugs, and make the code more useful. The releases are supported by the maintainers, community and users, on a best efforts basis only, and are not intended for customers who want enterprise or commercial support; Docker EE is the appropriate product for these use cases.


Legal

Brought to you courtesy of our legal counsel. For more context, please see the NOTICE document in this repo.

Use and transfer of Moby may be subject to certain restrictions by the United States and other governments.

It is your responsibility to ensure that your use and/or transfer does not violate applicable laws.

For more information, please see https://www.bis.doc.gov

Licensing

Moby is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.