如何从 GCP Container Registry 中提取 docker 图像列表?
How to extract list of docker images from GCP Container Registry?
我想获取我在特定项目上上传的所有 docker 图片的列表。
我用的是官方SDKhttps://pkg.go.dev/cloud.google.com/go
根据我的理解,清单应该在容器模块下。但是,我找不到任何可以达到目的的名为 ListImages 或 ListRepositories 的方法。
我检查了 artifactregistry 模块,但似乎只有在我将图像推送到 artifact registry 时它才有用。
在 golang 中获取 docker 图像列表(项目明智)的正确方法是什么?
我认为我们没有容器注册表的客户端库。因为它只是 Docker 注册表 API 根据这个 thread 至少
的一个实现
您尝试过注册表包吗? https://pkg.go.dev/github.com/docker/docker/registry
对于存储库,您可以使用 hostname/project-id。其中主机名是 gcr.io 或 eu.gcr.io 或 us.gcr.io 取决于您在 GCR 中的存储库是如何配置的。
golang 方法(在 运行: gcloud auth configure-docker
之后测试):
package main
import (
"context"
"fmt"
"log"
"github.com/google/go-containerregistry/pkg/authn"
gcr "github.com/google/go-containerregistry/pkg/name"
"github.com/google/go-containerregistry/pkg/v1/google"
"github.com/google/go-containerregistry/pkg/v1/remote"
)
func main() {
auth, err := google.NewGcloudAuthenticator()
if err != nil {
log.Fatal(err)
}
fmt.Println(auth)
registry, err := gcr.NewRegistry("gcr.io")
if err != nil {
log.Fatal(err)
}
ctx := context.Background()
repos, err := remote.Catalog(ctx, registry, remote.WithAuthFromKeychain(authn.DefaultKeychain))
if err != nil {
log.Fatal(err)
}
for _, repo := range repos {
fmt.Println(repo)
}
}
回复:
&{0xc0000000}
project-id/imagename
REST API 方法:
您可以像这样列出图像(将 gcr.io 替换为您的 gcr 端点,例如 gcr.io、us.gcr.io、asia.gcr.io 等) :
curl -H "Authorization: Bearer $(gcloud auth print-access-token)" "https://gcr.io/v2/_catalog"
回复:
{"repositories":["project-id/imagename"]}
您可以从这个 link 中找到有关令牌获取的一些相关详细信息:
PS:如果您有权访问多个项目,则必须从响应中过滤掉项目特定图像
我想获取我在特定项目上上传的所有 docker 图片的列表。
我用的是官方SDKhttps://pkg.go.dev/cloud.google.com/go
根据我的理解,清单应该在容器模块下。但是,我找不到任何可以达到目的的名为 ListImages 或 ListRepositories 的方法。
我检查了 artifactregistry 模块,但似乎只有在我将图像推送到 artifact registry 时它才有用。
在 golang 中获取 docker 图像列表(项目明智)的正确方法是什么?
我认为我们没有容器注册表的客户端库。因为它只是 Docker 注册表 API 根据这个 thread 至少
的一个实现您尝试过注册表包吗? https://pkg.go.dev/github.com/docker/docker/registry
对于存储库,您可以使用 hostname/project-id。其中主机名是 gcr.io 或 eu.gcr.io 或 us.gcr.io 取决于您在 GCR 中的存储库是如何配置的。
golang 方法(在 运行: gcloud auth configure-docker
之后测试):
package main
import (
"context"
"fmt"
"log"
"github.com/google/go-containerregistry/pkg/authn"
gcr "github.com/google/go-containerregistry/pkg/name"
"github.com/google/go-containerregistry/pkg/v1/google"
"github.com/google/go-containerregistry/pkg/v1/remote"
)
func main() {
auth, err := google.NewGcloudAuthenticator()
if err != nil {
log.Fatal(err)
}
fmt.Println(auth)
registry, err := gcr.NewRegistry("gcr.io")
if err != nil {
log.Fatal(err)
}
ctx := context.Background()
repos, err := remote.Catalog(ctx, registry, remote.WithAuthFromKeychain(authn.DefaultKeychain))
if err != nil {
log.Fatal(err)
}
for _, repo := range repos {
fmt.Println(repo)
}
}
回复:
&{0xc0000000}
project-id/imagename
REST API 方法:
您可以像这样列出图像(将 gcr.io 替换为您的 gcr 端点,例如 gcr.io、us.gcr.io、asia.gcr.io 等) :
curl -H "Authorization: Bearer $(gcloud auth print-access-token)" "https://gcr.io/v2/_catalog"
回复:
{"repositories":["project-id/imagename"]}
您可以从这个 link 中找到有关令牌获取的一些相关详细信息:
PS:如果您有权访问多个项目,则必须从响应中过滤掉项目特定图像