Docker 产品手册之 Docker Hub - 通过 GitHub 实现自动构建

2023-05-16

原文地址

如果你已经将 Docker Hub 链接到了你的 GitHub 账户,直接跳到第五小节 创建自动构建。

1. 将 Docker Hub 链接到 GitHub 账户

注意:因为 Docker Hub 需要设置 GitHub 的 service hook,自动构建需要读写权限。我们别无选择,这就是 GitHub 管理权限的方式。我们保证不会碰你帐户中的任何其他内容。

要为 GitHub 中的仓库设置自动构建,需要将 Docker Hub 链接到你的 GitHub 账户。这将允许 registry 查看你的 GitHub 仓库。

要增加、删除或查看已经链接的账户,请转至 Hub 配置文件“Settings”的“Linked Accounts & Services”部分。

authorized-services

链接时,选择“Public and Private”或“Limited Access”链接。

add-authorized-github-service

“Public and Private”选项最容易使用,这会授予 Docker Hub 完整的访问你的仓库的权限。GitHub 也允许你将属于你所在的 GitHub 组织的仓库授权。

选择“Public and Private”选项时,Docker Hub 只会得到访问公开数据和公开仓库的权限。

按照屏幕上的说明授权并将你的 GitHub 帐户链接到 Docker Hub。链接后,可以选择要从中创建自动构建的源仓库。

可以通过访问 GitHub 用户的“Applications”设置来查看和撤销 Docker Hub 的访问权限。

注意:如果删除用于其中一个自动构建仓库的 GitHub 帐户链接,先前构建的镜像仍可用。如果你稍后重新链接到该 GitHub 帐户,则可以使用 Hub 上的“Start Build”按钮启动自动构建,或者如果 GitHub 仓库上的 webhook 仍然存在,任何后续提交都会触发自动构建。

2. 自动构建和限制链接的 GitHub 帐户

如果你选择仅将 GitHub 帐户与“Limited Access”链接关联,那么在创建自动构建之后,需要使用“Start a Build”按钮手动触发 Docker Hub 构建,或者手动添加 GitHub webhook, 如 GitHub Service Hooks 中所述。这仅适用于用户帐户下的仓库,无法使用“Limited Access”链接向公共的 GitHub 组织添加自动构建。

3. 改变 GitHub 用户链接

如果你想要删除或更改 GitHub 帐户和 Docker Hub 之间的链接级别,则需要在两个位置执行此操作。

首先,从 Docker Hub 的“Settings”中删除“Linked Account”。然后转到 GitHub 帐户的个人设置,然后在“Applications”部分中的“Revoke access”。

现在可以随时重新链接账户。

4. GitHub 组织

GitHub 组织和由组织 fork 的私有仓库可用于使用“Docker Hub Registry”应用程序自动构建,该应用程序需要添加到组织中,然后应用于所有用户。

要检查或请求访问,请转到你的 GitHub 用户的“Setting”页面,从左侧栏中选择“Applications”部分,然后单击“View”按钮以查看“Docker Hub Registry”。

gh-check-user-org-dh-app-access

组织的管理员可能需要在“Settings”中转到组织的“Third party access”页面来授权或禁止访问 Docker Hub Registry 应用程序。此更改会用于所有的组织成员。

gh-check-admin-org-dh-app-access

可以使用 GitHub 的“People and Teams”界面管理对特定用户和 GitHub 仓库更具体的访问控制。

5. 创建自动构建

可以从任何具有 Dockerfile 的公有或私有 GitHub 仓库创建自动构建。

一旦选择了源代码库,你可以配置:

  • 仓库构建的 Hub 用户/组织命名空间 - 你的 Docker ID 名称或帐户所在的任何组织的名称
  • 镜像构建的 Docker 仓库名称
  • 仓库描述
  • 如果 Docker 仓库的可见性:“Public”或“Private”你可以在创建仓库后更改可访问性选项。如果你将 Private 仓库添加到 Hub 用户命名空间,那么你只能将其他用户添加为协作者,并且这些用户可以查看并提取该仓库中的所有镜像。要配置更细化的访问权限(例如使用用户团队或允许不同用户访问不同的镜像标签),则需要将私有仓库添加到你有管理员权限的 Hub 组织。
  • 当提交被推送到 GitHub 仓库时,启用或禁用重新构建 Docker 镜像。

你也可以选择一个或多个:

  • git 分支/标签,
  • 用作上下文的仓库子目录,
  • Docker 镜像标签名称

可以通过单击仓库视图的“Description”部分来修改仓库的描述。当下一个构建被触发时,“Full Description”被 README.md 文件覆盖。

6. GitHub 私有子模块(private submodules)

如果你的 GitHub 仓库包含指向私有子模块的链接,则构建失败。

通常,Docker Hub 会在你的 GitHub 仓库中设置一个部署密钥。不幸的是,GitHub 只允许一个仓库部署密钥访问一个仓库。

要解决此问题,可以在 GitHub 中创建一个专用用户帐户,并附加帐户的自动构建部署密钥。这个专用的构建帐户可以限制为只需访问构建所需的仓库。

1. 首先,在 GitHub 中创建新帐户。它应该被授予对主仓库和所有需要的子模块的只读访问权限。

gh_org_members

2. 这可以通过将帐户添加到保存主 GitHub 仓库和所有子模块仓库的组织中的只读团队来完成。

gh_team_members

3. 接下来,从主 GitHub 仓库中删除部署密钥。这可以在 GitHub 仓库的“Deploy keys”设置部分完成。

gh_repo_deploy_key

4. 自动构建的部署密钥位于“Deploy keys”下的“Build Details”菜单中。

deploy_key

5. 在你的专用 GitHub 用户帐户中,从 Docker Hub 自动构建中添加部署密钥。

gh_add_ssh_user_key

7. GitHub 服务钩子(service hooks)

GitHub 服务钩子允许 GitHub 在某个指定的 git 仓库发送提交操作时通知 Docker Hub。

当从 GitHub 创建一个具有完全“Public and Private”链接的自动构建时,Service Hook 应该会自动添加到你的 GitHub 仓库中。

如果你的 GitHub 帐户到 Docker Hub 的链接是“Limited Access”,那么需要手动添加服务钩子。

要添加、确认或修改服务钩子,请登录到 GitHub,然后导航到仓库,单击“Settings”(齿轮),然后选择“Webhooks & Services”。你必须拥有管理员权限才能查看或修改此设置。

下图显示了“Docker”服务钩子。

github-side-hook

如果手动添加“Docker”服务,请确保选中“Active”复选框,然后单击“Update service”按钮以保存更改。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Docker 产品手册之 Docker Hub - 通过 GitHub 实现自动构建 的相关文章

  • 双系统Ubuntu分区

    假设整个空闲空间有200G xff0c 主要分4个区 xff1a 1 给系统分区EFI xff1a 在唯一的一个空闲分区上添加 xff0c 大小200M xff0c 逻辑分区 xff0c 空间起始位置 xff0c 用于efi xff1b 这
  • 2 用D435i运行VINS-fusion

    文章目录 1 VINS fusion的安装1 1 环境和依赖的安装1 2 编译VINS Fusion1 3 编译错误解决方法 2 VINS Fusion跑数据集3 用相机运行VINS Fusion 环境 xff1a Ubuntu20 04
  • Python每日一个小程序

    前几天上网 xff0c 收集了20多道Python练习题 这些练习题还是很有价值的 xff0c 正好最近忙着复习准备校招 xff0c 可以用来练手 我会把每道题都写一篇博客详细阐述解题思路和源代码 xff0c 在每道题目后面附上博客地址 希
  • 数分下(第1讲):一阶微分方程的三类模型求解

    第1 1讲 xff1a 一阶微分方程的解法 第一周第一讲将用3个小时时间 xff0c 完整讲解一阶微分方程y 61 f x y 的三种典型模型求解方法 掌握以下知识点 xff0c 并熟练做题训练 对应同济高数教材第七章1 4节 知识点脑图如
  • 非常详细的 Linux C/C++ 学习路线总结!助我拿下腾讯offer

    点击关注上方 五分钟学算法 xff0c 设为 置顶或星标 xff0c 第一时间送达干货 转自后端技术学堂 正文 我的另一篇文章 腾讯 C 43 43 后台开发面试笔试知识点参考笔记 整理了 C 43 43 后台开发知识点 xff0c 本文尝
  • 一线互联网公司程序员技术面试的流程以及注意事项

    先来了解面试的流程是什么 xff0c 然后再一一做准备 xff01 企业一般通过几轮技术面试来考察大家的各项能力 xff0c 一般流程如下 xff1a 一面机试 xff1a 一般会考选择题和编程题 二面基础算法面 xff1a 就是基础的算法
  • 为什么C++永不过时?

    Linus曾说过 xff1a C 43 43 是一门很恐怖的语言 xff0c 而比它更恐怖的是很多不合格的程序员在使用着它 xff01 这足以说明C 43 43 有多难 xff01 不过 xff0c 你也要明白 难度越高意味着含金量与竞争力
  • STM32 USB学习笔记6

    主机环境 xff1a Windows 7 SP1 开发环境 xff1a MDK5 14 目标板 xff1a STM32F103C8T6 开发库 xff1a STM32F1Cube库和STM32 USB Device Library 现在来分
  • Invalid bound statement (not found)

    目录 一 遇到的问题 二 分析思路 1 映射文件 2 测试类 三 解决方案 一 遇到的问题 前几日 xff0c 有个工作不久的同事找我帮他解决一个 Mybatis 的问题 他写了一个增删改查 xff0c 但是在启动程序的时候报错 xff1a
  • ThinkPHP6 解决小程序调用接口返回错误是网页的尴尬

    背景 早在开始了解ThinkPHP时就一直记得一段话 xff1a 在一开始无知的我以为出现错误后能在调试阶段优雅的了解错误信息 xff0c 但结果大家试一下便知道 xff0c 十分尴尬 尤其是当在小程序里请求api xff0c 在过程中发生
  • 大数据技术Canal总结和详细案例

    0 Canal介绍 Canal 是用 Java 开发的基于数据库增量日志解析 xff0c 提供增量数据订阅 amp 消费的中间件 目前Canal 主要支持了 MySQL 的 Binlog 解析 xff0c 解析完成后才利用 Canal Cl
  • T507 Ubuntu18.04 LXDE桌面汉化

    本文硬件平台采用飞凌T507开发板 xff0c 主要讲解Ubuntu图形桌面LXDE如何修改为中文界面 xff0c 本文使用的思路和方法仅供参考使用 xff0c 其它arm开发板虽然芯片不同 xff0c 但思路和方法有很多的共性 xff0c
  • 工作站和台式机的区别

    转自 xff1a 微点阅读 xff08 www weidianyuedu com xff09 微点阅读 范文大全 免费学习网站 工作站电脑非常高配 xff0c 那么它和台式机有什么区别呢 下面由小编给你做出详细的工作站和台式机区别介绍 希望
  • 分布式锁-简单入门

    状态不是很好 xff0c 记一下以前学过的分布式锁吧 样例简介 不谈大概念 xff0c 就是简单入门以及使用 为什么要用分布式锁呢 xff1f 假设我需要一个定时操作 xff0c 每天在某个点 xff0c 我要处理一批数据 xff0c 要先
  • 深度神经网络的成功应用,深度神经网络发展历程

    深度学习与神经网络有什么区别 深度学习与神经网络关系2017 01 10最近开始学习深度学习 xff0c 基本上都是zouxy09博主的文章 xff0c 写的蛮好 xff0c 很全面 xff0c 也会根据自己的思路 xff0c 做下删减 x
  • Ubuntu22.04启用root账户 2208120941

    Ubuntu22 04启用root账户 2208120941 Ubuntu是有root账户的 只是没有密码 所以无法切换 所以启用的方法是 管理员账户用 sudo passwd root 给 root 设置密码 span class tok
  • WARNING: CLOCK SKEW DETECTED. YOUR BUILD MAY BE INCOMPLETE

    make时遇到这个问题几次了 xff0c 就记录一下吧 WARNING CLOCK SKEW DETECTED YOUR BUILD MAY BE INCOMPLETE 警告 xff1a 检测到时钟偏移 您的构建可能不完整 xff08 来自
  • ROS学习(五):构建系统

    ROS的构建系统默认使用CMake xff08 Cross Platform Make xff09 xff0c 其构建环境在功能 包目录中的CMakeLists txt文件中描述 在ROS中 xff0c CMake被修改为适合于ROS的 c
  • ROS学习(七):三维可视化工具(RViz)

    RViz是ROS的三维可视化工具 它的主要目的是以三维方式显示ROS消息 xff0c 可以将 数据进行可视化表达 例如 xff0c 可以无需编程就能表达激光测距仪 xff08 LRF xff09 传感器中的传感 器到障碍物的距离 xff0c
  • 你想拥有开挂的人生吗?

    此前 xff0c 时任百度首席科学家的吴恩达 xff0c 在接受机器之心视频专访时曾提及 xff0c 我想对所有还在考虑自己的职业生涯的年轻人说一句 xff0c 我知道当你很年轻的时候 xff0c 有时候你无法确定该追求怎样的事业 我认为我

随机推荐