重磅!GitHub 推出容器镜像仓库服务!
更多精彩内容可以订阅我的博客:https://fuckcloudnative.io
![](https://filescdn.proginn.com/4847a904a4e29b84ca2609164a71a0c3/fbcd1f4a363543989823e90c1a815838.webp)
微软收购了 GitHub
之后,并没有破坏 GitHub 的中立性,而是不断给开发者带来惊喜,从 GitHub Actions,到 GitHub Package Registry[1],Github 依旧是原来的那个 GitHub。
自从 GitHub Package Registry[2] 发布以来,已经有数亿个包被下载,其中 Docker
是仅次于 npm
的第二大流行的包管理工具,用户越来越倾向于使用容器、Kubernetes
和其他云原生技术来管理应用的生命周期。
虽然 GitHub Packages 已经为我们提供了强大的软件供应链的可追溯性,但在开发体验方面还做的不够好。现在 GitHub 单独推出了容器镜像仓库服务(GitHub Container Registry),改善了 GitHub Packages 对容器支持的不足,准备向 Docker Hub[3] 发起挑战。
GitHub 容器镜像仓库服务提供了公共镜像和私有镜像,和 Docker Hub 一样,公共镜像是免费的,可以匿名拉取。私有镜像现阶段(测试阶段)是免费的,正式上线后将和 GitHub Package Registry 采用相同的定价模式。
另外,GitHub 容器镜像仓库服务的域名是 ghcr.io
,不知道 gcr.io
会作何感想。
如果你无法拉取 gcr.io 的镜像,可以在公众号后台回复 gcr 获取镜像加速服务。
下面来教大家如何登陆 GitHub 容器镜像仓库服务:
创建 token
① 在 GitHub 任何页面的右上角,单击你的头像,然后单击 Settings。
![](https://filescdn.proginn.com/ffdbad455ba1b067b35d7ef4146c8c41/2f0cddffbf60434990d5e018d43eb3f8.webp)
② 在左侧边栏中,单击 Developer settings。
![](https://filescdn.proginn.com/eddeee300c6b141c6855772408cbbb3a/dc946de5fb892c88fa0b374bc38dc279.webp)
③ 在左侧边栏中,单击 Personal access tokens。
![](https://filescdn.proginn.com/e509a1efd1f70e041cc5d2953d83613b/749eff304df62ebb0a19a76b8f46e07f.webp)
④ 单击 Generate new token。
![](https://filescdn.proginn.com/64f3f5d09952d78effcf59261d6a70f7/b29e928b31aff8340ed2c5ed65fba5c7.webp)
⑤ 输入 token 名称
![](https://filescdn.proginn.com/225a7492549763c35755a5b180e33f49/c57ec6636cec08932c3c10e9e6fec1be.webp)
⑥ 选择 read:packages
以下载容器镜像,读取元数据;选择 write:packages
以下载上传容器镜像,读取写入元数据;选择 delete:packages
以删除容器镜像。
![](https://filescdn.proginn.com/4d462677d1625f9d142cb963ccffc380/0a9d774cf946fb09afa26f32232d01ff.webp)
登录镜像仓库
将之前创建的 token 保存为环境变量:
$ export CR_PAT=YOUR_TOKEN
登录镜像仓库,用户名使用 GitHub 的用户名:
$ echo $CR_PAT | docker login ghcr.io -u USERNAME --password-stdin
> Login Succeeded
然后就可以愉快地 push 私有镜像了。你也可以选择将 GitHub Actions 中的 registry 换成 ghcr.io
,享受 GitHub 带来的一条龙服务,例如:
name: ci
on:
push:
branches: master
jobs:
login:
runs-on: ubuntu-latest
steps:
-
name: Checkout
uses: actions/checkout@v2
-
name: Login to GitHub Package Registry
uses: docker/login-action@v1
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GHCR_TOKEN }}
最后,GitHub 容器镜像仓库服务未来还计划支持更多的云原生功能,包括 Helm 应用商店以及支持除了 Docker 镜像之外的其他类型存储。
Hacker News 的某位读者评论一语道破天机:如果微软推出容器服务,有些人是不会买的。但是,GitHub 的容器服务,他们就会买。我认为,这就是微软收购 GitHub 的部分原因。
参考资料
GitHub Package Registry: https://github.com/features/packages
[2]GitHub Package Registry: https://github.com/features/packages
[3]Docker Hub: https://hub.docker.com/
你可能还喜欢
点击下方图片即可阅读
云原生是一种信仰 ?
扫码关注公众号
后台回复◉k8s◉获取史上最方便快捷的 Kubernetes 高可用部署工具,只需一条命令,连 ssh 都不需要!
![](https://filescdn.proginn.com/36e68a17567e01afc65fd1f00cdf5e52/b6cf671958e6417267a42f3065c6d909.webp)
点击 "阅读原文" 获取更好的阅读体验!
❤️给个「在看」,是对我最大的支持❤️