aboutsummaryrefslogtreecommitdiff
path: root/users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go
diff options
context:
space:
mode:
authorFranck Cuny <franck.cuny@gmail.com>2021-04-13 19:41:04 -0700
committerFranck Cuny <franck@fcuny.net>2022-06-11 13:57:41 -0700
commit452f452dbecb216a819de0eac2186b96504bdd4a (patch)
tree4e0124db11f910cb41d2aae9a7a2c308d9452f00 /users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go
parentdoc: update README (diff)
downloadinfra-452f452dbecb216a819de0eac2186b96504bdd4a.tar.gz
pull a container into a namespace
Pull an image provided as an argument to the program. We're only interested in images for Linux/amd64 at the moment. We setup a default namespace for containerd named `c2vm`. Images that will be pulled by containerd will be stored inside that namespace. Once the program is build it can be run like this: ``` ; sudo ./c2vm -container docker.io/library/redis:latest pulled docker.io/library/redis:latest (38667897 bytes) ``` And the image is indeed in the namespace: ``` ; sudo ctr -n c2vm images ls -q docker.io/library/redis:latest ```
Diffstat (limited to 'users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go')
-rw-r--r--users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go56
1 files changed, 56 insertions, 0 deletions
diff --git a/users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go b/users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go
new file mode 100644
index 0000000..4d0968b
--- /dev/null
+++ b/users/fcuny/exp/containerd-to-vm/cmd/c2vm/main.go
@@ -0,0 +1,56 @@
+package main
+
+import (
+ "context"
+ "flag"
+ "fmt"
+ "log"
+
+ "github.com/containerd/containerd"
+ "github.com/containerd/containerd/namespaces"
+ "github.com/containerd/containerd/platforms"
+ ocispec "github.com/opencontainers/image-spec/specs-go/v1"
+)
+
+const (
+ containerdSock = "/run/containerd/containerd.sock"
+ defaultNamespace = "c2vm"
+)
+
+var (
+ platform = platforms.Only(ocispec.Platform{
+ OS: "linux",
+ Architecture: "amd64",
+ })
+)
+
+func main() {
+ var (
+ containerName = flag.String("container", "", "Name of the container")
+ )
+
+ flag.Parse()
+
+ if *containerName == "" {
+ log.Fatal("a container is required")
+ }
+
+ client, err := containerd.New(containerdSock)
+ if err != nil {
+ log.Fatalf("failed to create a client for containerd: %v", err)
+ }
+ defer client.Close()
+
+ ctx := namespaces.WithNamespace(context.Background(), defaultNamespace)
+ image, err := client.Pull(ctx, *containerName, containerd.WithPlatformMatcher(platform))
+ if err != nil {
+ log.Fatalf("failed to pull the container %s: %v\n", *containerName, err)
+ }
+
+ imageSize, err := image.Usage(ctx, containerd.WithUsageManifestLimit(1))
+ if err != nil {
+ log.Fatalf("failed to get the size of the image: %v", err)
+ }
+
+ fmt.Printf("pulled %s (%d bytes)\n", image.Name(), imageSize)
+}