管理内容


Red Hat Satellite 6.13

管理来自红帽和自定义源的内容的指南

Red Hat Satellite Documentation Team

摘要

使用本指南了解和管理 Satellite 6 中的内容。此类内容的示例包括 RPM 文件和 ISO 镜像。Red Hat Satellite 6 使用应用程序生命周期中提升的一组内容视图来管理此内容。本指南演示了如何创建适合您机构和内容视图的应用程序生命周期,以便在生命周期环境中获得实际的主机状态。这些内容视图最终形成在 Red Hat Satellite 6 环境中置备和更新主机的基础。

向红帽文档提供反馈

我们感谢您对我们文档的反馈。让我们了解如何改进它。

使用 Red Hat JIRA 中的 Create Issue 表单提供您的反馈。JIRA 问题在 Red Hat Satellite Jira 项目中创建,您可以在其中跟踪其进度。

前提条件

流程

  1. 单击以下链接: 创建问题。如果 Jira 显示登录错误,则登录并在您重定向到表单后继续。
  2. 完成 SummaryDescription 字段。在 Description 字段中,包含文档 URL、章节号以及问题的详细描述。不要修改表单中的任何其他字段。
  3. Create

第 1 章 内容管理简介

在卫星环境中,内容 定义为系统上安装的软件。这包括但不仅限于基础操作系统、中间件服务和最终用户应用程序。借助 Red Hat Satellite,您可以在软件生命周期的每个阶段管理 Red Hat Enterprise Linux 系统的各种内容类型。

Red Hat Satellite 管理以下内容:

订阅管理
这为组织提供了一种管理其红帽订阅信息的方法。
内容管理
这为组织提供了一种以各种方式存储红帽内容并对其进行组织的方法。

第 2 章 内容类型概述

使用 Red Hat Satellite,您可以管理以下内容类型:

RPM 软件包
从与红帽订阅相关的软件仓库导入 RPM 软件包。Satellite 服务器从红帽的内容交付网络下载 RPM 文件并将其存储在本地。您可以在内容视图中使用这些存储库及其 RPM 文件。
Kickstart 树
导入用于创建系统的 kickstart 树。新系统通过网络访问这些 kickstart 树,以用作其安装的基本内容。Red Hat Satellite 还包含一些预定义的 kickstart 模板,以及自行创建用来配置系统和自定义安装的功能。

您还可以在 Satellite 中管理其他类型的自定义内容。例如:

ISO 和 KVM 镜像
下载和管理用于安装和配置的介质。例如,Satellite 下载、存储并管理特定 Red Hat Enterprise Linux 和非红帽操作系统的 ISO 镜像和客户机镜像。
自定义文件类型
您可以为您需要的任何类型的文件类型管理自定义内容,如 SSL 证书和 OVAL 文件。

第 3 章 管理红帽订阅

Red Hat Satellite 可以从 Red Hat Content Delivery Network (CDN)导入内容。Satellite 需要红帽订阅清单,以便从相应的存储库查找、访问和下载内容。您必须有一个红帽订阅清单,其中包含 Satellite 服务器上每个机构的订阅分配。所有订阅信息均可在您的红帽客户门户网站帐户中获得。

在完成本章中的任务前,您必须在客户门户网站中创建红帽订阅清单。

请注意,基于权利的订阅模型已弃用,并将在以后的发行版本中删除。红帽建议您改用简单内容访问的基于访问 的订阅服务

要在客户门户网站中创建、管理和导出红帽订阅清单,请参阅在 Subscription Central 中为连接的 Satellite 服务器创建和管理清单

使用本章导入红帽订阅清单,并在 Satellite Web UI 中管理清单。

订阅分配和机构

如果您有多个订阅分配,您可以管理多个机构。Satellite 需要为每个在卫星服务器中配置的组织分配。这样做的好处是,每个组织都维护单独的订阅,以便支持多个机构,每个机构都有自己的红帽帐户。

未来的订阅

您可以在订阅分配中使用未来日期的订阅。当您在现有订阅的到期日期前将未来日期的订阅添加到内容主机时,您可以对存储库有不间断的访问。

在当前订阅过期前,手动将未来日期的订阅附加到您的内容主机。不要依赖 auto-attach 方法,因为此方法是为不同的目的而设计的,且可能无法正常工作。更多信息请参阅 第 3.6 节 “将红帽订阅附加到内容主机”

当将来的订阅处于活跃状态时,您必须刷新清单以同步存储库内容。如需更多信息,请参阅 第 3.5 节 “更新和刷新红帽订阅清单”

3.1. 将 Red Hat 订阅清单导入到 Satellite 服务器中

使用以下步骤将红帽订阅清单导入到 Satellite 服务器中。

注意

在组织中设置了简单内容访问(SCA),而不是清单。导入清单不会更改您组织的 Simple Content Access 状态。

前提条件

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Content > Subscriptions 并点 Manage Manifest
  3. Manage Manifest 窗口中,单击 Choose File
  4. 导航到包含红帽订阅清单文件的位置,然后单击 Open

CLI 过程

  1. 将红帽订阅清单文件从本地机器复制到 Satellite 服务器:

    $ scp ~/manifest_file.zip root@satellite.example.com:~/.
  2. root 用户身份登录 Satellite 服务器,再导入 Red Hat 订阅清单文件:

    # hammer subscription upload \
    --file ~/manifest_file.zip \
    --organization "My_Organization"

现在,您可以启用软件仓库并导入红帽内容。如需更多信息,请参阅 管理内容 中的 导入内容

3.2. 查找红帽订阅

当您将红帽订阅清单导入到 Satellite 服务器时,清单中的订阅会在 Subscriptions 窗口中列出。如果您有大量订阅,您可以过滤结果以查找特定的订阅。

前提条件

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Content > Subscriptions
  3. 在 Subscriptions 窗口中,点 Search 字段查看构建搜索查询的搜索条件列表。
  4. 选择搜索条件来显示更多选项。
  5. 构建搜索查询后,点搜索图标。

例如,如果您在 Search 字段中放置光标并选择 过期,然后按空格栏,则会出现另一个列表,其中包含放置 >、& lt; 或 = 字符的选项。如果您选择 & gt; 并按空格键,则会出现另一个自动选项列表。您还可以输入自己的标准。

3.3. 在订阅分配中添加红帽订阅

使用以下步骤在 Satellite Web UI 中的订阅分配中添加红帽订阅。

前提条件

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Content > Subscriptions
  3. 在 Subscriptions 窗口中,单击 Add Subscriptions
  4. 在您要添加的每个订阅行中,在 Allocate 列输入 Quantity 中的数量。
  5. Submit

3.4. 从订阅分配中删除红帽订阅

使用以下步骤从 Satellite Web UI 中的订阅分配中删除红帽订阅。

注意

清单不能被删除。如果您从红帽客户门户网站或 Satellite Web UI 中删除清单,则所有内容主机的权利都会被删除。

前提条件

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Content > Subscriptions
  3. 在您要删除的每个订阅行中,选择对应的复选框。
  4. 单击 Delete,然后确认删除。

3.5. 更新和刷新红帽订阅清单

每次更改订阅分配时,您必须刷新清单以反映这些更改。例如,如果要执行以下操作,您必须刷新清单:

  • 续订订阅
  • 调整订阅数量
  • 购买其他订阅

您可以直接在 Satellite Web UI 中刷新清单。或者,您可以导入包含更改的更新清单。

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Content > Subscriptions
  3. 在 Subscriptions 窗口中,单击 Manage Manifest
  4. 在 Manage Manifest 窗口中,单击 Refresh

3.6. 将红帽订阅附加到内容主机

使用激活密钥是在置备过程中将订阅附加到内容主机的主要方法。但是,激活密钥无法更新现有的主机。如果您需要将新订阅或附加订阅(如未来日期的订阅)附加到一个主机,请使用以下步骤。

重要

只有在 Satellite 上禁用了简单内容访问(SCA)时,这个步骤才有效。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

有关更新多个主机的详情,请参考 第 3.7 节 “更新多个主机上的红帽订阅”

有关激活码的详情请参考 第 9 章 管理激活码

Satellite 订阅

在 Satellite 中,您必须为您要管理的每个 Red Hat Enterprise Linux 主机维护一个 Red Hat Enterprise Linux Satellite 订阅(以前称为 Red Hat Enterprise Linux 智能管理)。

但是,您不需要将 Satellite 订阅附加到每个内容主机。Satellite 订阅无法自动附加到 Satellite 中的内容主机,因为它们不与任何产品证书关联。在内容主机中添加 Satellite 订阅不提供任何内容或存储库访问。如果需要,您可以在清单中添加 Satellite 订阅,以便您自己的记录或跟踪目的。

前提条件

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Hosts > Content Hosts
  3. 在您要更改的每个内容主机的行中,选择对应的复选框。
  4. Select Action 列表中,选择 Manage Subscriptions
  5. (可选)在 Search 字段中输入键和值来过滤显示的订阅。
  6. 选中您要添加或删除的订阅左侧的复选框,再根据需要单击 Add SelectedRemove Selected
  7. Done 保存更改。

CLI 过程

  1. 在 Satellite 服务器上列出所有可用的订阅:

    # hammer subscription list \
    --organization-id My_Organization_ID
  2. 将订阅附加到您的受管主机:

    # hammer host subscription attach \
    --host My_Host_Name \
    --subscription-id My_Subscription_ID

3.7. 更新多个主机上的红帽订阅

使用此流程同时对多个内容主机进行安装后更改。

重要

只有在 Satellite 上禁用了简单内容访问(SCA)时,这个步骤才有效。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

流程

  1. 在 Satellite Web UI 中,确保将上下文设置为您要使用的组织。
  2. 在 Satellite Web UI 中,导航到 Hosts > Content Hosts
  3. 在您要更改的每个内容主机的行中,选择对应的复选框。
  4. Select Action 列表中,选择 Manage Subscriptions
  5. (可选)在 Search 字段中输入键和值来过滤显示的订阅。
  6. 选中要添加或删除的订阅左侧的复选框,再根据需要单击 Add SelectedRemove Selected
  7. Done 保存更改。

第 4 章 管理备用内容源

备用内容源定义在同步期间下载内容的备用路径。内容本身从备用内容源下载,而元数据则从 Satellite 服务器或上游 URL 下载,具体取决于配置。如果内容位于本地文件系统或接近网络中,您可以使用备用内容源加快同步。您可以为 Satellite 服务器和 Capsule 设置备用内容源。您必须在创建后或进行任何更改后刷新备用内容源。每周 cron 作业会刷新所有备用内容源。您还可以使用 Satellite Web UI 或hammer CLI 手动刷新备用内容源。与 Satellite 服务器关联的备用内容源或附加到多个组织的胶囊服务器会影响所有组织。

有三种备用内容源:

Custom
自定义备用内容源从网络或文件系统的任何上游存储库下载内容。
简化的
简化备用内容源,从您的 Satellite 服务器复制上游存储库信息,以用于所选产品。简化的备用内容源非常适合,从 Capsule 到上游存储库的连接比 Satellite 服务器更快。在创建简化的备用内容源时选择红帽产品,将从红帽 CDN 将内容下载到 Capsule 中。
RHUI
RHUI 备用内容源从 Red Hat Update Infrastructure 服务器下载内容。Satellite Web UI 提供了一些示例,可帮助您找到网络路径并导入身份验证凭据。RHUI 备用内容源必须是 RHUI 版本 4 或更高版本,并使用默认安装配置。例如,不支持 AWS RHUI,因为它使用具有唯一身份验证要求的安装场景。

Alternate 内容源的权限要求

非管理员用户必须具有以下权限来管理备用内容源:

  1. view_smart_proxies
  2. view_content_credentials
  3. view_organizations
  4. view_products

除了以上权限外,根据用户可以执行的操作,分配特定于备用内容源的权限:

  1. view_alternate_content_sources
  2. create_alternate_content_sources
  3. edit_alternate_content_sources
  4. destroy_alternate_content_sources

4.1. 配置自定义 Alternate 内容源

前提条件

流程

  1. 在 Satellite Web UI 中,导航到 Content > Alternate Content Sources
  2. 单击 Add Source,将 Source 类型设置为 Custom
  3. 选择内容类型
  4. Name 字段中输入备用内容源的名称。
  5. 可选:在 Description 字段中,为 ACS 提供描述。
  6. 选择要同步备用内容源的 Capsule。
  7. 输入备用内容源的基本 URL。
  8. 输入以逗号分隔的 Subpath 列表。
  9. 如果需要,请提供 Manual Authentication 或 Content Authentication 凭证。
  10. 如果需要 SSL 验证,请启用 Verify SSL 并选择 SSL CA 证书。
  11. 查看详情并点 Add
  12. 导航到 Content > Alternate Content Sources > 点新创建的备用内容源 > Select Refresh 旁的垂直 ellipsis。

CLI 过程

  1. 在 Satellite 服务器中输入以下命令:

    # hammer alternate-content-source create \
    --name "My_ACS_Name" \
    --alternate-content-source-type custom \
    --base-url "https://local-repo.example.com:port" \
    --smart-proxy-ids Capsule_ID
  2. 检查是否列出了新创建的备用内容源:

    # hammer alternate-content-source list
  3. 刷新备用内容源:

    # hammer alternate-content-source refresh --id My_Alternate_Content_Source_ID
  4. 添加要同步备用内容源的胶囊:

    # hammer alternate-content-source update \
    --id My_Alternate_Content_Source_ID \
    --smart-proxy-ids Capsule_ID
  5. 刷新备用内容源:

    # hammer alternate-content-source refresh --id My_Alternate_Content_Source_ID

4.2. 配置简化的 Alternate 内容源

流程

  1. 在 Satellite Web UI 中,导航到 Content > Alternate Content Sources
  2. 单击 Add Source,并将 Source 类型设置为 Simplified
  3. 选择内容类型
  4. Name 字段中输入备用内容源的名称。
  5. 可选:在 Description 字段中,为 ACS 提供描述。
  6. 选择要同步备用内容源的 Capsule。
  7. 可选: 如果您希望 ACS 使用 Capsule 服务器的 HTTP 代理,请选择 Use HTTP proxy。
  8. 选择应使用备用内容源的产品。
  9. 查看详情并点 Add
  10. 导航到 Content > Alternate Content Sources,点新创建的备用内容源旁的垂直 ellipsis,然后选择 Refresh

CLI 过程

  1. 创建简化的 ACS:

    # hammer alternate-content-source create \
    --name My_ACS_Name \
    --alternate-content-source-type simplified \
    --smart-proxy-ids MyCapsule_ID_ \
    --product-ids My_Product_ID
  2. 检查新创建的 ACS 是否已列出:

    # hammer alternate-content-source list
  3. 刷新 ACS:

    # hammer alternate-content-source refresh --id My_ACS_ID

4.2.1. 直接从红帽 CDN 同步 Capsule

您可以使用简化的备用内容源将 Capsule 配置为直接从红帽 CDN 同步内容。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Alternate Content Sources
  2. 单击 Add Source,并将 Source 类型设置为 Simplified
  3. 内容类型设置为 Yum
  4. Name 字段中输入备用内容源的名称。
  5. 可选:在 Description 字段中,为备用内容源提供描述。
  6. 选择您要直接从红帽 CDN 同步的 Capsules。
  7. 可选: 如果您希望 ACS 使用 Capsule 服务器的 HTTP 代理,请选择 Use HTTP proxy。
  8. 从 Red Hat CDN 选择应当与 Capsule 同步的红帽产品。
  9. 查看详情并点 Add
  10. 导航到 Content > Alternate Content Sources,点新创建的备用内容源旁的垂直 ellipsis,然后选择 Refresh

Capsule 现在将从红帽 CDN 下载内容,而不是 Satellite。

4.3. 配置 RHUI Alternate 内容源

前提条件

流程

  1. 在 Satellite Web UI 中,导航到 Content > Alternate Content Sources
  2. 单击 Add Source,并将 Source 类型设置为 RHUI
  3. 使用 Satellite Web UI 中提供的命令生成 RHUI 证书。确保传递所需存储库的 repo 标签。
  4. Name 字段中输入备用内容源的名称。
  5. 可选:在 Description 字段中,为 ACS 提供描述。
  6. 选择要同步备用内容源的 Capsule。
  7. 可选: 如果您希望 ACS 使用 Capsule 的 HTTP 代理,请选择 Use HTTP proxy。
  8. 输入 Red Hat Update Infrastructure CDS 节点的 Base URL。
  9. 输入以逗号分隔的 Subpath 列表。
  10. 如果需要 请提供内容凭据。
  11. 如果需要 SSL 验证,请启用 Verify SSL 并选择 SSL CA 证书。
  12. 查看详情并点 Add
  13. 导航到 Content > Alternate Content Sources,点新创建的备用内容源旁的垂直 ellipsis,然后选择 Refresh

CLI 过程

  1. 在 Satellite 服务器中输入以下命令:

    # hammer alternate-content-source create \
    --name "My_ACS_Name" \
    --alternate-content-source-type rhui \
    --base-url "https://rhui-cds-node/pulp/content" \
    --subpaths path/to/repo/1/,path/to/repo/2/ \
    --ssl-client-cert-id My_SSL_Client_Certificate_ID \
    --ssl-client-key-id My_SSL_Client_Key_ID \
    --smart-proxy-ids MyCapsule_ID_ \
    --verify-ssl 1
  2. 检查是否列出了新创建的备用内容源:

    # hammer alternate-content-source list
  3. 刷新备用内容源:

    # hammer alternate-content-source refresh --id My_Alternate_Content_Source_ID
  4. 添加要同步备用内容源的胶囊:

    # hammer alternate-content-source update \
    --id My_Alternate_Content_Source_ID \
    --smart-proxy-ids Capsule_ID
  5. 刷新备用内容源:

    # hammer alternate-content-source refresh --id My_Alternate_Content_Source_ID

第 5 章 导入内容

本章概述了如何将不同类型的自定义内容导入到 Satellite。如果要将 RPM、文件或不同的内容类型导入到 Satellite,则本章中的大体与流程相同。

例如,您可以使用以下章节来获取有关特定类型的自定义内容的信息,但底层步骤相同:

5.1. Satellite 中的产品和软件仓库

Satellite 中的红帽内容和自定义内容都有相似性:

  • 产品及其存储库之间的关系是相同的,存储库仍需要同步。
  • 自定义产品需要订阅主机才能访问,类似于红帽产品的订阅。Satellite 会为每个您创建的自定义产品创建一个订阅。

红帽内容已组织到产品中。例如,Red Hat Enterprise Linux Server 是 Satellite 中的 产品。该产品的软件仓库由不同的版本、架构和附加组件组成。对于红帽存储库,产品会在启用存储库后自动创建。更多信息请参阅 第 5.5 节 “启用红帽存储库”

其他内容可以组织到自定义产品,但您想要。例如,您可以创建一个 EPEL (Extra Packages for Enterprise Linux)产品,并为其添加一个"EPEL 7 x86_64"存储库。

有关创建和打包 RPM 的更多信息,请参阅 Red Hat Enterprise Linux RPM 打包指南

5.2. 导入自定义 SSL 证书

在从外部源同步自定义内容前,您可能需要将 SSL 证书导入到自定义产品中。这可能包括您要同步的上游存储库的客户端证书和密钥或 CA 证书。

如果您需要 SSL 证书和密钥下载 RPM,可以将它们添加到 Satellite 中。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Credentials。在 Content Credentials 窗口中,单击 Create Content Credential
  2. Name 字段中输入 SSL 证书的名称。
  3. Type 列表中,选择 SSL Certificate
  4. Content Credentials Content 字段中,粘贴 SSL 证书,或者点击 Browse 上传您的 SSL 证书。
  5. Save

CLI 过程

  1. 将 SSL 证书复制到 Satellite 服务器中:

    $ scp My_SSL_Certificate root@satellite.example.com:~/.

    或者从在线源下载 SSL 证书到您的 Satellite 服务器:

    $ wget -P ~ http://upstream-satellite.example.com/pub/katello-server-ca.crt
  2. 将 SSL 证书上传到 Satellite:

    # hammer content-credential create \
    --content-type cert \
    --name "My_SSL_Certificate" \
    --organization "My_Organization" \
    --path ~/My_SSL_Certificate

5.3. 创建自定义产品

创建自定义产品,以便您可以将存储库添加到自定义产品中。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,点 Create Product
  2. Name 字段中输入产品名称。Satellite 根据您为名称输入的内容自动完成 Label 字段
  3. 可选: 在 GPG Key 列表中,选择产品的 GPG 密钥。
  4. 可选: 在 SSL CA Cert 列表中,为该产品选择 SSL CA 证书。
  5. 可选: 在 SSL 客户端 Cert 列表中,为该产品选择 SSL 客户端证书。
  6. 可选: 在 SSL Client Key 列表中,选择产品的 SSL 客户端密钥。
  7. 可选: 在 Sync Plan 列表中,选择一个现有的迁移计划,或者点击 Create Sync Plan 并为您的产品要求创建一个迁移计划。
  8. Description 字段中,输入产品的描述。
  9. Save

CLI 过程

运行以下命令来创建产品:

# hammer product create \
--name "My_Product" \
--sync-plan "Example Plan" \
--description "Content from My Repositories" \
--organization "My_Organization"

5.4. 添加自定义 RPM 存储库

使用这个流程在 Satellite 中添加自定义 RPM 存储库。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

Satellite Web UI 中的 Products 窗口也提供了一个 Repo Discovery 功能,从 URL 中找到所有存储库,您可以选择要添加到自定义产品中的存储库。例如,您可以使用 Repo Discovery 搜索 http://yum.postgresql.org/9.5/redhat/ 并列出不同 Red Hat Enterprise Linux 版本和构架的所有软件仓库。这有助于用户节省时间,从单个源导入多个存储库。

支持自定义 RPM

红帽不支持直接来自第三方站点的上游 RPM。这些 RPM 用于演示同步过程。对于这些 RPM 的问题,请联系第三方开发人员。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,再选择要使用的产品,然后单击 New Repository
  2. Name 字段中输入存储库的名称。Satellite 根据您为名称输入的内容自动完成 Label 字段
  3. 可选:在 Description 字段中输入存储库的描述。
  4. Type 列表中,选择 yum 作为存储库类型。
  5. 可选:从 Restrict to Architecture 列表中选择一个架构。如果您想使存储库可供所有主机使用,无论架构如何,请确保选择 不限制
  6. 可选: 从 Restrict to OS Version 列表中,选择 OS 版本。如果要使存储库可供所有主机使用,无论操作系统版本是什么,请确保选择 No limits
  7. 可选:在 Upstream URL 字段中,输入要用作源的外部存储库的 URL。Satellite 支持三种协议: http://https://file://。如果您使用的是 file:// 存储库,您必须将它放在 /var/lib/pulp/sync_imports/ 目录中。

    如果没有输入上游 URL,您可以手动上传软件包。

  8. 可选:选中 Ignore SRPMs 复选框,将源 RPM 软件包没有同步到 Satellite。
  9. 如果要验证上游存储库的 SSL 证书是否由可信 CA 签名,请选择 Verify SSL 复选框。
  10. 可选:在 Upstream Username 字段中,如果需要身份验证,请为上游存储库输入用户名。如果存储库不需要身份验证,请清除此字段。
  11. 可选:在 Upstream Password 字段中,输入上游存储库的对应密码。如果存储库不需要身份验证,请清除此字段。
  12. 可选:在 Upstream Authentication Token 字段中,提供上游存储库用户的令牌进行身份验证。如果存储库不需要身份验证,请将此字段留空。
  13. Download Policy 列表中,选择同步卫星服务器所执行的类型。更多信息请参阅 第 5.8 节 “下载策略概述”
  14. Mirroring Policy 列表中,选择内容同步卫星服务器所执行的类型。更多信息请参阅 第 5.11 节 “镜像策略概述”
  15. 可选:在 Retain 软件包版本字段中,输入您要为每个软件包保留的版本数量
  16. 可选: 在 HTTP Proxy Policy 字段中,选择一个 HTTP 代理。
  17. Checksum 列表中,选择存储库的校验和类型。
  18. 可选:您可以清除 Unprotected 复选框,要求订阅授权证书才能访问此存储库。默认情况下,存储库通过 HTTP 发布。
  19. 可选: 在 GPG Key 列表中,选择产品的 GPG 密钥。
  20. 可选: 在 SSL CA Cert 字段中,为存储库选择 SSL CA 证书。
  21. 可选: 在 SSL Client cert 字段中,为存储库选择 SSL 客户端证书。
  22. 可选: 在 SSL Client Key 字段中,选择存储库的 SSL Client Key。
  23. 单击 Save 以创建存储库。

CLI 过程

  1. 输入以下命令来创建存储库:

    # hammer repository create \
    --arch "My_Architecture" \
    --content-type "yum" \
    --gpg-key-id My_GPG_Key_ID \
    --name "My_Repository" \
    --organization "My_Organization" \
    --os-version "My_OS_Version" \
    --product "My_Product" \
    --publish-via-http true \
    --url My_Upstream_URL

继续 同步存储库

5.5. 启用红帽存储库

如果外部网络访问需要使用 HTTP 代理,请为您的服务器配置默认的 HTTP 代理。如需更多信息,请参阅 向 Satellite 添加默认 HTTP 代理

要选择要同步的存储库,您必须首先识别包含存储库的产品,然后根据相关发行版本和基本架构启用该存储库。

对于 Red Hat Enterprise Linux 8 主机

要置备 Red Hat Enterprise Linux 8 主机,您需要 Red Hat Enterprise Linux 8 for x86_64 - AppStream (RPMs)Red Hat Enterprise Linux 8 for x86_64 - BaseOS (RPMs) 软件仓库。

对于 Red Hat Enterprise Linux 7 主机

要配置 Red Hat Enterprise Linux 7 主机,您需要 Red Hat Enterprise Linux 7 Server (RPMs) 存储库。

将 Red Hat Enterprise Linux 操作系统发行版本与 7Server 存储库或 7 的关联之间的区别在于 7Server 存储库包含所有最新的更新,而 Red Hat Enterprise Linux 7X 软件仓库会在下一个次版本发布后停止更新。请注意: Kickstart 软件仓库只有一个次版本。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Red Hat Repositories
  2. 要查找存储库,请输入存储库名称,或者将 recommended Repositories 按钮切换到 on 位置,以查看您需要的存储库列表。
  3. 在 Available Repositories 窗格中,单击存储库以展开存储库集。
  4. 点基本架构和发行版本旁的 Enable 图标。

CLI 过程

  1. 要搜索您的产品,请输入以下命令:

    # hammer product list --organization "My_Organization"
  2. 列出为产品设置的存储库:

    # hammer repository-set list \
    --product "Red Hat Enterprise Linux Server" \
    --organization "My_Organization"
  3. 使用名称或 ID 号启用存储库。包含发行版本,如 7Server,以及基本架构,如 x86_64

    # hammer repository-set enable \
    --name "Red Hat Enterprise Linux 7 Server (RPMs)" \
    --releasever "7Server" \
    --basearch "x86_64" \
    --product "Red Hat Enterprise Linux Server" \
    --organization "My_Organization"

5.6. 同步软件仓库

您必须同步存储库,才能将内容下载到 Satellite 中。您可以使用这个步骤进行存储库的初始同步,或者根据需要手动同步存储库。

您还可以同步机构中的所有存储库。更多信息请参阅 第 5.7 节 “同步机构中的所有存储库”

创建迁移计划以确保定期进行更新。更多信息请参阅 第 5.19 节 “创建迁移计划”

同步持续时间取决于每个存储库的大小以及网络连接的速度。下表提供了根据可用的互联网带宽来同步内容所需的时间:

 单个软件包(10Mb)次发行版本(750Mb)主发行版本(6Gb)

256 Kbps

5 分钟 27 Sec

6 hrs 49 Mins 36 Secs

2 天 7 Hrs 55 Mins

512 Kbps

2 mins 43.84 Secs

3 个 hrs 24 次 48 Sec

1 天 3 个 Hrs 57 Mins

T1 (1.5 Mbps)

54.33 secs

1 HR 7 Mins 54.78 Sec

9 hrs 16 Mins 20.57 Secs

10 Mbps

8.39 secs

10 分钟 29.15 Secs

1 HR 25 Mins 53.96 Secs

100 Mbps

0.84 secs

1 min 2.91 Sec

8 mins 35.4 Secs

1000 Mbps

0.08 secs

6.29 secs

51.54 secs

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,再选择包含您要同步的存储库的产品。
  2. 选择您要同步的存储库,然后单击 Sync Now
  3. 可选: 要在 Satellite Web UI 中查看同步的进度,请导航到 Content > Sync Status 并展开对应的产品或存储库树。

CLI 过程

  • 同步整个产品:

    # hammer product synchronize \
    --name "My_Product" \
    --organization "My_Organization"
  • 同步单个软件仓库:

    # hammer repository synchronize \
    --name "My_Repository" \
    --organization "My_Organization" \
    --product "My Product"

5.7. 同步机构中的所有存储库

使用这个流程同步机构中的所有软件仓库。

流程

  1. 使用 SSH 登录您的 Satellite 服务器。
  2. 运行以下 Bash 脚本:

    ORG="My_Organization"
    
    for i in $(hammer --no-headers --csv repository list --organization $ORG --fields Id)
    do
      hammer repository synchronize --id ${i} --organization $ORG --async
    done

5.8. 下载策略概述

Red Hat Satellite 为同步 RPM 内容提供多个下载策略。例如,您可能希望仅下载内容元数据,同时将实际内容推迟到以后下载。

Satellite 服务器有以下策略:

immediate
卫星服务器在同步期间下载所有元数据和软件包。
on Demand
卫星服务器仅在同步期间下载元数据。当胶囊或直接连接的客户端请求时,卫星服务器仅在文件系统中获取和存储软件包。如果将胶囊上的对应存储库设置为 Immediate,则此设置无效,因为卫星服务器被强制下载所有软件包。

On Demand 策略充当了 Lazy Synchronization 功能,因为它们节省了时间同步内容。lazy 同步功能必须仅用于 yum 存储库。您可以将软件包添加到内容视图,并正常提升到生命周期环境。

胶囊式服务器有以下策略:

immediate
胶囊式服务器在同步期间下载所有元数据和软件包。如果卫星服务器上的对应存储库设为 On Demand,则不要使用此设置,因为卫星服务器被强制下载所有软件包。
on Demand
胶囊式服务器仅在同步期间下载元数据。当直接连接的客户端请求时,胶囊式服务器才会获取并存储在文件系统中。使用 On Demand 下载策略时,如果胶囊服务器上不可用,则内容将从卫星服务器下载。
inherit
胶囊式服务器从卫星服务器上对应的存储库继承存储库的下载策略。
流化下载策略
Capsule 的流下载策略允许 Capsules 避免缓存任何内容。从 Capsule 请求内容时,它将充当代理,并直接从 Satellite 请求内容。

5.9. 更改默认下载策略

您可以设置 Satellite 应用到在所有机构中创建的存储库的默认下载策略。

根据它是红帽还是非红帽自定义存储库,Satellite 会使用单独的设置。更改默认值不会更改现有设置。

流程

  1. 在 Satellite Web UI 中,导航到 Administer > Settings
  2. 单击 内容选项卡
  3. 根据您的要求更改默认下载策略:

    • 要更改红帽存储库的默认下载策略,请更改 Default Red Hat Repository download policy 设置的值。
    • 要更改自定义存储库的默认下载策略,请更改 Default Custom Repository download policy 设置的值。

CLI 过程

  • 要将红帽存储库的默认下载策略改为 立即on_demand 之一,请输入以下命令:

    # hammer settings set \
    --name default_redhat_download_policy \
    --value immediate
  • 要将非红帽自定义存储库的默认下载策略更改为 立即on_demand 之一,请输入以下命令:

    # hammer settings set \
    --name default_download_policy \
    --value immediate

5.10. 更改存储库的下载策略

您可以为存储库设置下载策略。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择所需的产品名称。
  3. Repositories 选项卡上,单击所需的存储库名称,找到 Download Policy 字段,然后单击 edit 图标。
  4. 从列表中,选择所需的下载策略,然后单击 Save

CLI 过程

  1. 列出机构的软件仓库:

    # hammer repository list \
    --organization-label My_Organization_Label
  2. 将存储库的下载策略更改为 immediateon_demand

    # hammer repository update \
    --download-policy immediate \
    --name "My_Repository" \
    --organization-label My_Organization_Label \
    --product "My_Product"

5.11. 镜像策略概述

镜像使本地存储库与上游存储库完全同步。如果自上一次同步以来从上游存储库中删除任何内容,则也会将其从本地存储库中删除。

您可以使用镜像策略来更精细地控制同步存储库时 repodata 和内容的镜像。例如,如果无法为存储库镜像 repodata,您可以将镜像策略设置为仅镜像此存储库的内容。

Satellite 服务器有以下镜像策略:

additive
内容和 repodata 都不会被镜像(mirror)。因此,只有自上次同步以来添加的新内容才会添加到本地存储库中,不会删除任何内容。
仅限内容
仅镜像内容,而不是 repodata。有些存储库不支持元数据镜像,在这种情况下,您可以将镜像策略设置为仅镜像内容。
完整的镜像(mirror)
镜像内容和 repodata。这是最快的方法。此镜像策略仅适用于 Yum 内容。

5.12. 更改存储库的镜像策略

您可以为存储库设置镜像策略。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择产品名称。
  3. Repositories 选项卡上,单击存储库名称,找到 Mirroring Policy 字段,然后单击 edit 图标。
  4. 从列表中,选择一个镜像策略,再单击 Save

CLI 过程

  1. 列出机构的软件仓库:

    # hammer repository list \
    --organization-label My_Organization_Label
  2. 更改存储库的镜像策略,以添加、mirror_complete、或 mirror_content_only

    # hammer repository update \
    --id 1 \
    --mirroring-policy mirror_complete

5.13. 将内容上传到自定义 RPM 存储库

您可以将单独的 RPM 和源 RPM 上传到自定义 RPM 软件仓库。您可以使用 Satellite Web UI 或hammer CLI 上传 RPM。您必须使用 Hammer CLI 上传源 RPM。

流程

  1. 在 Satellite Web UI 中,点 Content > Products
  2. 点自定义产品的名称。
  3. Repositories 选项卡中,单击自定义 RPM 存储库的名称。
  4. Upload Package 下,点 Browse…​ 并选择您要上传的 RPM。
  5. Upload

要查看此存储库中的所有 RPM,请单击 Content Counts 下的 软件包 旁边的数字。

CLI 过程

  • 输入以下命令上传 RPM:

    # hammer repository upload-content \
    --id Repository_ID \
    --path /path/to/example-package.rpm
  • 输入以下命令上传源 RPM:

    # hammer repository upload-content \
    --content-type srpm \
    --id Repository_ID \
    --path /path/to/example-package.src.rpm

    上传完成后,您可以使用 hammer srpm 列表和 hammer srpm info --id srpm info --id srpm_ID 查看源 RPM 的信息。

5.14. 在自定义端口上将 SELinux 配置为 Permit 内容同步

SELinux 仅允许 Satellite 访问特定端口上的内容同步。默认情况下,连接到在以下端口上运行的 Web 服务器:80、81、443、488、8008、8009 8443 和 9000。

流程

  1. 在 Satellite 中,要验证 SELinux 允许进行内容同步的端口,请按如下所示输入命令:

    # semanage port -l | grep ^http_port_t
    http_port_t     tcp      80, 81, 443, 488, 8008, 8009, 8443, 9000
  2. 要将 SELinux 配置为允许内容同步的端口,如 10011,请输入如下命令:

    # semanage port -a -t http_port_t -p tcp 10011

5.15. 恢复正确的存储库

如果出现存储库崩溃,您可以使用高级同步来恢复它,该同步有三个选项:

优化的同步
同步存储库,绕过没有检测到与上游 RPM 差异的 RPM。
完全同步
无论检测到的更改如何,都会同步所有 RPM。如果特定的 RPM 无法下载到本地存储库,则使用这个选项,即使它们存在于上游存储库中。
验证内容检查

同步所有 RPM,然后在本地验证所有 RPM 的校验和。如果 RPM 的校验和与上游不同,它会重新下载 RPM。这个选项只适用于 yum 软件仓库。如果您有以下错误之一,则使用这个选项:

  • 特定的 RPM 在与 yum 同步时会导致 404 错误。
  • 软件包与预期的下载错误不匹配,这意味着特定的 RPM 已损坏。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择包含损坏存储库的产品。
  3. 选择您要同步的存储库的名称。
  4. 要执行优化的同步或完成同步,请从 Select Action 菜单中选择 Advanced Sync
  5. 选择所需选项并点 Sync
  6. 可选: 要验证校验和,请点击 Select Action 菜单中的 Verify Content Checksum

CLI 过程

  1. 获取存储库 ID 列表:

    # hammer repository list \
    --organization "My_Organization"
  2. 使用所需选项同步损坏的存储库:

    • 对于优化的同步:

      # hammer repository synchronize \
      --id My_ID
    • 对于完整的同步:

      # hammer repository synchronize \
      --id My_ID \
      --skip-metadata-check true
    • 对于 validate 内容同步:

      # hammer repository synchronize \
      --id My_ID \
      --validate-contents true

5.16. 添加 HTTP 代理

使用这个流程在 Satellite 中添加 HTTP 代理。然后,您可以指定要用于产品、存储库和受支持的计算资源的 HTTP 代理。

前提条件

HTTP 代理必须允许访问以下主机:

主机名端口协议

subscription.rhsm.redhat.com

443

HTTPS

cdn.redhat.com

443

HTTPS

*.akamaiedge.net

443

HTTPS

cert.console.redhat.com (如果使用 Red Hat Insights)

443

HTTPS

api.access.redhat.com (如果使用 Red Hat Insights)

443

HTTPS

cert-api.access.redhat.com (如果使用 Red Hat Insights)

443

HTTPS

如果 Satellite 服务器使用代理与 subscription.rhsm.redhat.com 和 cdn.redhat.com 通信,则代理不得对这些通信执行 SSL 检查。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Infrastructure > HTTP Proxies 并选择 New HTTP Proxy
  2. Name 字段中输入 HTTP 代理的名称。
  3. URL 字段中输入 HTTP 代理的 URL,包括端口号。
  4. 如果您的 HTTP 代理需要身份验证,请输入 UsernamePassword
  5. 可选:在 Test URL 字段中输入 HTTP 代理 URL,然后点 Test Connection 以确保您可以从 Satellite 连接到 HTTP 代理。
  6. 单击位置选项卡 并添加位置。
  7. 单击组织选项卡并添加组织。
  8. Submit

CLI 过程

  • 在 Satellite 服务器中输入以下命令来添加 HTTP 代理:

    # hammer http-proxy create \
    --name proxy-name \
    --url proxy-URL:port-number

    如果您的 HTTP 代理需要身份验证,请添加 --username name-- password密码 选项。

如需更多信息,请参阅知识库文章 如何通过防火墙或红帽客户门户网站中的代理访问 Red Hat Subscription Manager (RHSM)

5.17. 更改产品的 HTTP 代理服务器

为了对网络流量进行精细控制,您可以为每个产品设置 HTTP 代理策略。产品 HTTP 代理策略适用于产品中的所有存储库,除非您为单个存储库设置了不同的策略。

要为单独的软件仓库设置 HTTP 代理策略,请参阅 第 5.18 节 “更改存储库的 HTTP 代理服务器”

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,再选中您要更改的每个产品旁边的复选框。
  2. Select Action 列表中,选择 Manage HTTP Proxy
  3. 从列表中选择 HTTP 代理策略

    • 全局默认 :使用全局默认代理设置。
    • 没有 HTTP 代理 : 不使用 HTTP 代理,即使配置了全局默认代理。
    • 使用特定的 HTTP 代理 :从列表中选择 HTTP 代理。您必须将 HTTP 代理添加到 Satellite,然后才能从此列表中选择代理。更多信息请参阅 第 5.16 节 “添加 HTTP 代理”
  4. 单击 Update

5.18. 更改存储库的 HTTP 代理服务器

为了对网络流量进行精细控制,您可以为每个存储库设置 HTTP 代理策略。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

要为产品中的所有软件仓库设置相同的 HTTP 代理策略,请参阅 第 5.17 节 “更改产品的 HTTP 代理服务器”

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,然后点击包含该存储库的产品名称。
  2. Repositories 选项卡中,单击存储库的名称。
  3. 找到 HTTP Proxy 字段,再单击编辑图标。
  4. 从列表中选择 HTTP 代理策略

    • 全局默认 :使用全局默认代理设置。
    • 没有 HTTP 代理 : 不使用 HTTP 代理,即使配置了全局默认代理。
    • 使用特定的 HTTP 代理 :从列表中选择 HTTP 代理。您必须将 HTTP 代理添加到 Satellite,然后才能从此列表中选择代理。更多信息请参阅 第 5.16 节 “添加 HTTP 代理”
  5. Save

CLI 过程

  • 在 Satellite 服务器中,输入以下命令指定您要使用的 HTTP 代理策略:

    # hammer repository update \
    --http-proxy-policy HTTP_Proxy_Policy \
    --id Repository_ID

    --http-proxy-policy 指定以下选项之一:

    • none :不使用 HTTP 代理,即使配置了全局默认代理。
    • global_default_http_proxy :使用全局默认代理设置。
    • use_selected_http_proxy: 使用 --http-proxy My_HTTP_Proxy_Name--http-proxy-id My_HTTP_Proxy_ID指定 HTTP 代理。要在 Satellite 中添加新 HTTP 代理,请参阅 第 5.16 节 “添加 HTTP 代理”

5.19. 创建迁移计划

同步计划检查并在计划的日期和时间更新内容。在 Satellite 中,您可以创建一个迁移计划,并为计划分配产品。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Sync Plans,再点 New Sync Plan
  2. Name 字段中输入计划的名称。
  3. 可选:在 Description 字段中输入计划描述。
  4. Interval 列表中,选择计划运行的时间间隔。
  5. Start DateStart Time 列表中,选择何时开始运行同步计划。
  6. Save

CLI 过程

  1. 运行以下命令来创建同步计划:

    # hammer sync-plan create \
    --description "My_Description" \
    --enabled true \
    --interval daily \
    --name "My_Products" \
    --organization "My_Organization" \
    --sync-date "2023-01-01 01:00:00"
  2. 查看某个机构的可用应用计划,以验证是否已创建了计划:

    # hammer sync-plan list --organization "My_Organization"

5.20. 将迁移计划分配给产品

同步计划检查并在计划的日期和时间更新内容。在 Satellite 中,您可以为产品分配计划来定期更新内容。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择一个产品。
  3. Details 标签页中,从下拉菜单中选择 Sync Plan

CLI 过程

  1. 为产品分配迁移计划:

    # hammer product set-sync-plan \
    --name "My_Product_Name" \
    --organization "My_Organization" \
    --sync-plan "My_Sync_Plan_Name"

5.21. 将一个同步计划分配给多个产品

使用这个流程为机构中至少同步并包含至少一个软件仓库的机构中的产品分配同步计划。

流程

  1. 运行以下 Bash 脚本:

    ORG="My_Organization"
    SYNC_PLAN="daily_sync_at_3_a.m"
    
    hammer sync-plan create --name $SYNC_PLAN --interval daily --sync-date "2023-04-5 03:00:00" --enabled true --organization $ORG
    for i in $(hammer --no-headers --csv --csv-separator="|" product list --organization $ORG --per-page 999 | grep -vi not_synced | awk -F'|' '$5 != "0" { print $1}')
    do
      hammer product set-sync-plan --sync-plan $SYNC_PLAN --organization $ORG --id $i
    done
  2. 执行脚本后,查看分配给迁移计划的产品:

    # hammer product list --organization $ORG --sync-plan $SYNC_PLAN

5.22. 限制同步并行

默认情况下,每个存储库同步作业可以一次获取最多十个文件。这可基于每个存储库进行调整。

增加限制可能会提高性能,但可能会导致上游服务器超载或开始拒绝请求。如果您因为上游服务器拒绝请求导致存储库同步失败,您可能需要尝试降低限制。

CLI 过程

# hammer repository update \
--download-concurrency 5 \
--id Repository_ID \
--organization "My_Organization"

5.23. 导入自定义 GPG 密钥

当客户端使用签名的自定义内容时,请确保客户端被配置为使用适当的 GPG 密钥验证软件包的安装。这有助于确保只能安装来自授权源的软件包。

红帽的内容已配置了适当的 GPG 密钥,因此不支持对 Red Hat 存储库进行 GPG 密钥管理。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

前提条件

确保您具有用于在 Satellite 中使用和管理的 RPM 内容签名的 GPG 密钥副本。大多数 RPM 分发提供程序在其网站上提供其 GPG 密钥。您还可以从 RPM 手动提取它:

  1. 将版本特定存储库软件包的副本下载到您的本地机器中:

    $ wget http://www.example.com/9.5/example-9.5-2.noarch.rpm
  2. 在不安装的情况下解压 RPM 文件:

    $ rpm2cpio example-9.5-2.noarch.rpm | cpio -idmv

GPG 密钥相对于位于 etc/pki/rpm-gpg/RPM-GPG-KEY-EXAMPLE-95 的提取。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Credentials,并在窗口右上角点击 Create Content Credential
  2. 输入存储库的名称,然后从 Type 列表中选择 GPG Key
  3. 将 GPG 密钥粘贴到 Content Credential Contents 字段中,或者点 Browse 并选择您要导入的 GPG 密钥文件。

    如果您的自定义存储库包含由多个 GPG 密钥签名的内容,您必须在 Content Credential Contents 字段中输入所有必需的 GPG 密钥,每个密钥之间都带有新行,例如:

    -----BEGIN PGP PUBLIC KEY BLOCK-----
    
    mQINBFy/HE4BEADttv2TCPzVrre+aJ9f5QsR6oWZMm7N5Lwxjm5x5zA9BLiPPGFN
    4aTUR/g+K1S0aqCU+ZS3Rnxb+6fnBxD+COH9kMqXHi3M5UNzbp5WhCdUpISXjjpU
    XIFFWBPuBfyr/FKRknFH15P+9kLZLxCpVZZLsweLWCuw+JKCMmnA
    =F6VG
    -----END PGP PUBLIC KEY BLOCK-----
    
    -----BEGIN PGP PUBLIC KEY BLOCK-----
    
    mQINBFw467UBEACmREzDeK/kuScCmfJfHJa0Wgh/2fbJLLt3KSvsgDhORIptf+PP
    OTFDlKuLkJx99ZYG5xMnBG47C7ByoMec1j94YeXczuBbynOyyPlvduma/zf8oB9e
    Wl5GnzcLGAnUSRamfqGUWcyMMinHHIKIc1X1P4I=
    =WPpI
    -----END PGP PUBLIC KEY BLOCK-----
  4. Save

CLI 过程

  1. 将 GPG 密钥复制到 Satellite 服务器中:

    $ scp ~/etc/pki/rpm-gpg/RPM-GPG-KEY-EXAMPLE-95 root@satellite.example.com:~/.
  2. 将 GPG 密钥上传到 Satellite:

    # hammer content-credentials create \
    --content-type gpg_key \
    --name "My_GPG_Key" \
    --organization "My_Organization" \
    --path ~/RPM-GPG-KEY-EXAMPLE-95

5.24. 将自定义存储库限制为 Satellite 中的特定操作系统或架构

您可以配置 Satellite,使其仅在具有特定操作系统版本或架构的主机上提供自定义存储库。例如,您只能将自定义软件仓库限制为 Red Hat Enterprise Linux 9 主机。

注意

仅限制自定义产品的架构和操作系统版本。Satellite 对红帽软件仓库自动应用这些限制。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 点包含您要限制的存储库集的产品。
  3. Repositories 选项卡中,点您要限制的存储库。
  4. Publishing Settings 部分中,设置以下选项:

    • Restrict to OS 版本 设置为限制操作系统版本。
    • Restrict to architecture 设置为限制架构。

第 6 章 管理应用程序生命周期

本章概述了卫星中的应用生命周期,以及如何为 Satellite 和 Capsule 创建和删除应用生命周期。

6.1. 应用程序生命周期简介

应用生命周期 是卫星内容管理功能的核心概念。应用程序生命周期定义了特定系统及其软件如何查看特定阶段。例如,应用程序生命周期可能很简单;您可能只有一个开发阶段和生产阶段。在这种情况下,应用程序生命周期可能类似如下:

  • 开发
  • Production

但是,更复杂的应用程序生命周期可能还有进一步阶段,如用于测试或 beta 版本的阶段。这会在应用程序生命周期中添加额外的阶段:

  • 开发
  • 测试
  • Beta 版本
  • Production

Satellite 提供了自定义每个应用生命周期阶段的方法,使其适合您的规格。

应用生命周期中的每个阶段在卫星中称为 环境。每个环境都使用特定的内容集合。Satellite 将这些内容集合定义为内容视图。每个内容视图都充当一个过滤器,您可以在其中定义特定环境中要包含哪些存储库和软件包。这为您提供了一个方法,用于定义指定到每个环境的特定内容集合。

例如,电子邮件服务器可能只需要一个简单的应用程序生命周期,因为您使用生产级服务器,以及用于尝试最新的邮件服务器软件包的测试服务器。当测试服务器通过初始阶段时,您可以将 production-level 服务器设置为使用新软件包。

另一个例子是软件产品的开发生命周期。要在开发环境中开发一个新软件,请在质量保证环境中进行测试,预发布为 beta 版,然后将软件作为生产级应用发布。

图 6.1. Satellite 应用程序生命周期

Satellite 应用程序生命周期

6.2. 应用程序生命周期中的内容提升

在应用程序生命周期链中,当内容从一个环境移到下一个环境时,这称为 提升

在 Satellite 生命周期阶段的内容提升示例

每个环境都包含一组注册到 Red Hat Satellite 的系统。这些系统只能访问与其环境相关的存储库。当您将软件包从一个环境提升到下一个环境时,目标环境的仓库会接收新的软件包版本。因此,目标环境中的每个系统都可以更新到新的软件包版本。

开发测试Production

example_software-1.1-0.noarch.rpm

example_software-1.0-0.noarch.rpm

example_software-1.0-0.noarch.rpm

在完成补丁上的开发后,您可以将软件包提升到测试环境,以便质量工程团队可以查看补丁。然后,应用程序生命周期在每个环境中包含以下软件包版本:

开发测试Production

example_software-1.1-0.noarch.rpm

example_software-1.1-0.noarch.rpm

example_software-1.0-0.noarch.rpm

虽然质量工程团队审查补丁,但开发团队开始在 example_software 2.0 上工作。这会生成以下应用程序生命周期:

开发测试Production

example_software-2.0-0.noarch.rpm

example_software-1.1-0.noarch.rpm

example_software-1.0-0.noarch.rpm

Quality Engineering 团队完成补丁的审查。现在 example_software 1.1 已准备好发布。将 1.1 提升到 Production 环境:

开发测试Production

example_software-2.0-0.noarch.rpm

example_software-1.1-0.noarch.rpm

example_software-1.1-0.noarch.rpm

Development 团队在 example_software 2.0 上完成其工作,并将其提升到测试环境:

开发测试Production

example_software-2.0-0.noarch.rpm

example_software-2.0-0.noarch.rpm

example_software-1.1-0.noarch.rpm

最后,质量工程团队将检查软件包。检查成功后,将软件包提升到 Production 环境:

开发测试Production

example_software-2.0-0.noarch.rpm

example_software-2.0-0.noarch.rpm

example_software-2.0-0.noarch.rpm

更多信息请参阅 第 7.3 节 “提升内容视图”

6.3. 创建生命周期管理路径

要为开发和释放软件创建应用生命周期,请使用 Library 环境作为初始环境来创建路径。然后,选择性地向路径添加额外的环境。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Lifecycle Environments
  2. 单击 New Environment Path 以启动新的应用程序生命周期。
  3. Name 字段中输入您的环境名称。
  4. Description 字段中,输入您的环境的描述。
  5. Save
  6. 可选: 要在环境路径中添加环境,请点击 Add New Environment,完成 NameDescription 字段,然后从 Prior Environment 列表中选择之前的环境。

CLI 过程

  1. 要创建路径,请输入 hammer lifecycle-environment create 命令,并使用 --prior 选项指定 Library 环境:

    # hammer lifecycle-environment create \
    --name "Environment Path Name" \
    --description "Environment Path Description" \
    --prior "Library" \
    --organization "My_Organization"
  2. 可选: 要在环境路径中添加环境,请输入 hammer lifecycle-environment create 命令并使用 --prior 选项指定父环境:

    # hammer lifecycle-environment create \
    --name "Environment Name" \
    --description "Environment Description" \
    --prior "Prior Environment Name" \
    --organization "My_Organization"
  3. 要查看生命周期环境的链,请输入以下命令:

    # hammer lifecycle-environment paths --organization "My_Organization"

6.4. 从 Satellite 服务器中删除生命周期环境

使用这个流程删除生命周期环境。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Life Cycle Environments
  2. 单击您要删除的生命周期环境的名称,然后单击 Remove Environment
  3. 单击 Remove 以删除该环境。

CLI 过程

  1. 列出您的机构的生命周期环境,并记录您要删除的生命周期环境的名称:

    # hammer lifecycle-environment list \
    --organization "My_Organization"
  2. 使用 hammer lifecycle-environment delete 命令删除环境:

    # hammer lifecycle-environment delete \
    --name "My_Environment" \
    --organization "My_Organization"

6.5. 从胶囊服务器中删除生命周期环境

当生命周期环境不再与主机系统或环境关联时,您可以将生命周期环境或环境错误地添加到胶囊服务器中,您可以从 Capsule 服务器中删除生命周期环境。

您可以使用 Satellite Web UI 和hammer CLI 从 Capsule 中删除生命周期阶段。

流程

  1. 在 Satellite Web UI 中,导航到 Infrastructure > Capsules,然后选择您要从中删除生命周期的 Capsule。
  2. 单击 Edit,再单击 Life Cycle Environments 选项卡。
  3. 从右侧菜单中选择您要从胶囊中删除的生命周期环境,然后单击 Submit
  4. 要同步胶囊的内容,请单击 Overview 选项卡,然后单击 Synchronize
  5. 选择 Optimized SyncComplete Sync

CLI 过程

  1. 从列表中选择 Capsule Server 并记下其 id

    # hammer capsule list
  2. 要验证 Capsule 服务器的详情,请输入以下命令:

    # hammer capsule info \
    --id MyCapsule_ID_
  3. 验证当前附加到 Capsule 服务器的生命周期环境列表,并记录 环境 ID

    # hammer capsule content lifecycle-environments \
    --id MyCapsule_ID_
  4. 从 Capsule 服务器中删除生命周期环境:

    # hammer capsule content remove-lifecycle-environment \
    --id MyCapsule_ID_
    --lifecycle-environment-id My_Lifecycle_Environment_ID

    对您要从 Capsule Server 中删除的每个生命周期环境重复此步骤。

  5. 将 Satellite 服务器环境中的内容同步到 Capsule 服务器:

    # hammer capsule content synchronize \
    --id My_capsule_ID

6.6. 将生命周期环境添加到胶囊服务器

如果您的胶囊服务器启用了内容功能,您必须添加环境,以便 Capsule 可以从 Satellite 服务器同步内容,并提供内容到主机系统。

不要将 Library 生命周期环境分配给您的 Capsule 服务器,因为它在每次 CDN 更新存储库时触发自动胶囊同步。这可能会在胶囊上使用多个系统资源、卫星和胶囊之间的网络带宽,以及胶囊上的可用磁盘空间。

您可以在 Satellite 服务器或 Satellite Web UI 上使用hammer CLI。

流程

  1. 在 Satellite Web UI 中,导航到 Infrastructure > Capsules,然后选择您要向其添加生命周期的 Capsule。
  2. 单击 Edit,再单击 Life Cycle Environments 选项卡。
  3. 在左侧菜单中选择您要添加到胶囊的生命周期环境,然后单击 Submit
  4. 若要同步胶囊的内容,请单击 Overview 选项卡,再单击 Synchronize
  5. 选择 Optimized SyncComplete Sync

    有关每个同步类型的定义 ,请参阅恢复存储库

CLI 过程

  1. 要显示所有胶囊服务器的列表,请在管理门户中输入以下命令:

    # hammer capsule list

    注意您要向其添加生命周期的胶囊的胶囊 ID。

  2. 使用 ID,验证您的胶囊的详情:

    # hammer capsule info \
    --id My_capsule_ID
  3. 要查看您的 Capsule 服务器可用的生命周期环境,请输入以下命令并记录 ID 和机构名称:

    # hammer capsule content available-lifecycle-environments \
    --id My_capsule_ID
  4. 将生命周期环境添加到您的胶囊服务器中:

    # hammer capsule content add-lifecycle-environment \
    --id My_capsule_ID \
    --lifecycle-environment-id My_Lifecycle_Environment_ID
    --organization "My_Organization"

    对您要添加到胶囊式服务器的每个生命周期环境重复此操作。

  5. 将内容从 Satellite 同步到 Capsule。

    • 要将 Satellite 服务器环境中的所有内容同步到 Capsule 服务器,请输入以下命令:

      # hammer capsule content synchronize \
      --id My_capsule_ID
    • 要将特定的生命周期环境从 Satellite 服务器同步到 Capsule 服务器,请输入以下命令:

      # hammer capsule content synchronize \
      --id My_capsule_ID
      --lifecycle-environment-id My_Lifecycle_Environment_ID

第 7 章 管理内容视图

Red Hat Satellite 使用内容视图来允许主机访问独立策展的内容子集。为此,您必须定义要使用哪些存储库,然后将某些过滤器应用到内容。这些过滤器包括软件包过滤器、软件包组过滤器、勘误过滤器、模块流过滤器和容器镜像标签过滤器。您可以使用内容视图来定义特定环境使用的软件版本。例如,生产环境 可能使用包含较旧的软件包版本的内容视图,而 开发环境 则可能使用包含较新软件包版本的内容视图。

或者,默认组织 视图是同步到 Satellite 的所有内容的应用控制的内容视图。如果要在 Satellite 中注册主机并使用订阅访问内容,而不操作内容视图和生命周期环境,则此类型很有用。

每个内容视图在每个环境中创建一组存储库,供卫星服务器存储和管理。当您将内容视图从一个环境提升到应用生命周期中的下一个环境时,卫星服务器上对应的存储库将更新并发布软件包。

 开发测试Production

内容视图版本和内容

版本 2 - example_software-1.1-0.noarch.rpm

版本 1 - example_software-1.0-0.noarch.rpm

版本 1 - example_software-1.0-0.noarch.rpm

用于 Testing 和 Production 的存储库包含 example_software-1.0-0.noarch.rpm 软件包。如果您将内容视图的版本 2 从 Development 提升到 Testing,则测试的存储库会重新生成,然后包含 example_software-1.1-0.noarch.rpm 软件包:

 开发测试Production

内容视图版本和内容

版本 2 - example_software-1.1-0.noarch.rpm

版本 2 - example_software-1.1-0.noarch.rpm

版本 1 - example_software-1.0-0.noarch.rpm

这样可确保系统被指定为特定的环境,但当该环境使用新版本的内容视图时接收更新。

创建用于过滤和创建快照的内容视图的一般工作流如下:

  1. 创建内容视图.
  2. 添加您要添加到内容视图的一个或多个存储库。
  3. 可选:创建一个或多个过滤器来优化内容视图的内容。更多信息请参阅 第 7.9 节 “内容过滤器示例”
  4. 可选:解决内容视图的任何软件包依赖项。更多信息请参阅 第 7.7 节 “解决软件包依赖项”
  5. 发布内容视图.
  6. 可选:将内容视图提升到另一个环境。更多信息请参阅 第 7.3 节 “提升内容视图”
  7. 将内容主机附加到内容视图。

如果存储库没有与内容视图关联,则文件 /etc/yum.repos.d/redhat.repo 仍然为空,且注册到它的系统无法接收更新。

主机只能与单个内容视图关联。要将主机与多个内容视图相关联,请创建一个复合内容视图。更多信息请参阅 第 7.5 节 “创建复合内容视图”

7.1. 创建内容视图

使用这个流程创建简单的内容视图。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

前提条件

虽然您可以通过内容视图来推断要解析任何软件包依赖项,但您可能希望更改默认的 Satellite 设置,以启用或禁用所有内容视图的软件包解析。更多信息请参阅 第 7.7 节 “解决软件包依赖项”

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views,再点 Create content view
  2. Name 字段中输入视图的名称。Satellite 会自动从您输入的名称完成 Label 字段。
  3. Description 字段中,输入视图的描述。
  4. Type 字段中,选择 Content viewComposite 内容视图
  5. 可选: 如果要在每次发布此内容视图时自动解决依赖项,请选择 Solv e 依赖项 复选框。依赖项解决会减慢发布时间,并可能会忽略您使用的任何内容视图过滤器。这也可能会在解析勘误表的依赖关系时导致错误。
  6. 可选: 如果要指定此内容视图以从上游服务器导入,请选择 Import only 复选框。只有导入的内容视图无法直接发布。
  7. Create 内容视图

内容视图步骤

  1. 单击 Create 内容视图 以创建 Content View。
  2. Repositories 选项卡中,从您要添加到内容视图的 Type 列表中选择存储库,选中您要添加的可用存储库旁边的复选框,然后单击 Add repositories
  3. 单击 Publish new version,然后在 Description 字段中输入有关版本的信息来记录更改。
  4. 可选: 您可以通过点 Promote 从可用提升路径中选择生命周期环境来启用提升路径,以升级新版本
  5. Next
  6. Review 页面中,您可以检查您要发布的环境。
  7. Finish

您可以在 Content Views 窗口中查看内容视图。要查看有关内容视图的更多信息,请单击内容视图名称。要将主机注册到您的内容视图, 请参阅管理主机中的 注册主机

CLI 过程

  1. 获取存储库 ID 列表:

    # hammer repository list --organization "My_Organization"
  2. 创建内容视图并添加存储库:

    # hammer content-view create \
    --description "My_Content_View" \
    --name "My_Content_View" \
    --organization "My_Organization" \
    --repository-ids 1,2

    对于 --repository-ids 选项,您可以在 hammer repository list 命令的输出中找到 ID。

  3. 发布视图:

    # hammer content-view publish \
    --description "My_Content_View" \
    --name "My_Content_View" \
    --organization "My_Organization"
  4. 可选: 要将存储库添加到现有内容视图中,请输入以下命令:

    # hammer content-view add-repository \
    --name "My_Content_View" \
    --organization "My_Organization" \
    --repository-id repository_ID

卫星服务器创建新版本的视图,并将其发布到 Library 环境。

7.2. 查看模块流

在 Satellite 中,您可以在内容视图中查看存储库的模块流。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到公布的内容视图 > Module Streams 版本,以查看可用于 Content Types 的模块流。
  2. 使用 Search 字段搜索特定模块。
  3. 若要查看模块的相关信息,请单击模块及其对应的选项卡,以包含 详细信息存储库配置文件和 工件

CLI 过程

  1. 列出所有机构:

    # hammer organization list
  2. 查看您的机构的所有模块流:

    # hammer module-stream list \
    --organization-id My_Organization_ID

7.3. 提升内容视图

使用此流程在不同的生命周期环境之间提升内容视图。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

内容视图提升的权限要求

非管理员用户需要两个权限才能将内容视图提升到环境:

  1. promote_or_remove_content_views
  2. promote_or_remove_content_views_to_environment.

promote_or_remove_content_views 权限限制用户可提升的内容视图。

promote_or_remove_content_views_to_environment 权限限制了用户可以提升内容视图的环境。

使用这些权限,您可以为用户分配权限,来将某些内容视图提升到某些环境,但不能将某些内容视图提升到其他环境。例如,您可以限制用户,使其能够提升到测试环境,但不能提升到生产环境。

您必须为用户分配这两个权限,以允许他们提升内容视图。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views,再选择您要提升的内容视图。
  2. 选择您要提升的版本,单击垂直 ellipsis 图标,然后单击 Promote
  3. 选择您要提升内容视图的环境,然后单击 Promote

现在,内容视图的存储库都出现在所有环境中。

CLI 过程

  • 为每个生命周期环境使用 Hammer 提升内容视图:

    # hammer content-view version promote \
    --content-view "Database" \
    --version 1 \
    --to-lifecycle-environment "Development" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Database" \
    --version 1 \
    --to-lifecycle-environment "Testing" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Database" \
    --version 1 \
    --to-lifecycle-environment "Production" \
    --organization "My_Organization"

    现在,数据库内容在所有环境中都可用。

  • 或者,您可以使用以下 Bash 脚本在机构中的所有生命周期环境中提升内容视图:

    ORG="My_Organization"
    CVV_ID=My_Content_View_Version_ID
    
    for i in $(hammer --no-headers --csv lifecycle-environment list --organization $ORG | awk -F, {'print $1'} | sort -n)
    do
       hammer content-view version promote --organization $ORG --to-lifecycle-environment-id $i --id $CVV_ID
    done

验证

  • 显示有关您的 Content View 版本的信息以验证它是否已提升到所需的生命周期环境:

    # hammer content-view version info --id My_Content_View_Version_ID

后续步骤

7.4. 复合内容视图概述

Composite Content View 将多个内容视图的内容组合起来。例如,您可以拥有单独的内容视图来分别管理操作系统和应用。您可以使用复合内容视图将两个内容视图的内容合并到新存储库中。原始内容视图的存储库仍然存在,但存在组合内容的新存储库。

如果要开发支持不同数据库服务器的应用程序。example_application 显示为:

example_software

Application(应用程序)

数据库

操作系统

四个单独的内容视图示例:

  • Red Hat Enterprise Linux (操作系统)
  • PostgreSQL (Database)
  • MariaDB (Database)
  • example_software (Application)

在之前的内容视图中,您可以创建两个 Composite 内容视图。

PostgreSQL 数据库的 Composite 内容视图示例:

复合内容视图 1 - PostgreSQL 上的 example_software

example_software (Application)

PostgreSQL (Database)

Red Hat Enterprise Linux (操作系统)

MariaDB 的 Composite 内容视图示例:

复合内容视图 2 - MariaDB 上的 example_software

example_software (Application)

MariaDB (Database)

Red Hat Enterprise Linux (操作系统)

然后,每个内容视图都会单独管理和发布。当您创建应用版本时,您将发布一个新版本的 Composite 内容视图。您还可以在创建 Composite Content View 时选择 Auto Publish 选项,然后在它包含重新发布的内容视图时自动重新发布 Composite Content View。

仓库限制

Docker 存储库不能包含在 Composite Content View 中多次。例如,如果您试图在 Composite Content View 中使用相同的 docker 存储库包含两个内容视图,则 Satellite 服务器会报告错误。

7.5. 创建复合内容视图

使用这个流程创建复合内容视图。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views,再点 Create content view
  2. Create 内容视图 窗口中,在 Name 字段中输入视图的名称。Red Hat Satellite 会自动从您输入的名称完成 Label 字段。
  3. 可选:在 Description 字段中输入视图的描述。
  4. Type 选项卡中,选择 Composite 内容视图
  5. 可选:如果您要在重新发布内容视图时自动发布 Composite Content View 的新版本,请选择 Auto publish 复选框。
  6. Create 内容视图
  7. 内容视图 选项卡上,选择要添加到 Composite Content View 的内容视图,然后单击 Add 内容视图
  8. Add 内容视图 窗口中,选择每个内容视图的版本。
  9. 可选:如果要自动将内容视图更新到最新版本,请选择 Always update to latest version 复选框。
  10. 单击 Add,然后单击 Publish new version
  11. 可选:在 Description 字段中,输入 Content View 的描述。
  12. Publish 窗口中,设置 Promote 开关,然后选择 生命周期环境。
  13. 单击下一步,然后单击 完成

CLI 过程

  1. 在创建 Composite Content Views 前,列出现有内容视图的版本 ID:

    # hammer content-view version list \
    --organization "My_Organization"
  2. 创建新的复合内容视图.当 --auto-publish 选项设置为 yes 时,当包含的内容视图被重新发布时,Compposite Content View 会自动重新发布:

    # hammer content-view create \
    --composite \
    --auto-publish yes \
    --name "Example_Composite_Content_View" \
    --description "Example Composite Content View" \
    --organization "My_Organization"
  3. 将内容视图添加到复合内容视图.您可以通过其 ID 或名称来识别命令中的内容视图、内容视图版本和机构。要在 Composite Content View 中添加多个内容视图,请对您要包含的每个内容视图重复此步骤。

    • 如果您为内容视图启用了 Always update to latest version 选项:

      # hammer content-view component add \
      --component-content-view-id Content_View_ID \
      --composite-content-view "Example_Composite_Content_View" \
      --latest \
      --organization "My_Organization"
    • 如果您为内容视图禁用了 Always update to latest version 选项:

      # hammer content-view component add \
      --component-content-view-id Content_View_ID \
      --composite-content-view "Example_Composite_Content_View" \
      --component-content-view-version-id Content_View_Version_ID \
      --organization "My_Organization"
  4. 发布 Composite 内容视图:

    # hammer content-view publish \
    --name "Example_Composite_Content_View" \
    --description "Initial version of Composite Content View" \
    --organization "My_Organization"
  5. 在所有环境中提升 Composite 内容视图:

    # hammer content-view version promote \
    --content-view "Example_Composite_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Development" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Example_Composite_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Testing" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Example_Composite_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Production" \
    --organization "My_Organization"

7.6. 内容过滤器概述

内容视图也使用过滤器来包括或限制某些 RPM 内容。如果没有这些过滤器,Content View 包含了来自所选存储库的所有内容。

内容过滤器有两种类型:

表 7.1. 过滤器类型
过滤器类型Description

Include

您以没有内容开头,然后从选定的仓库中选择要添加的内容。使用此过滤器组合多个内容项目。

exclude

您首先从选定存储库中的所有内容,然后选择要删除的内容。当您想使用大多数特定内容存储库但排除某些软件包(如列入黑名单的软件包)时,请使用此过滤器。过滤器使用存储库中的所有内容,但您选择的内容除外。

包括 和 Exclude Filter Combinations

如果使用 Include 和 Exclude 过滤器的组合,请发布内容视图首先触发 include 过滤器,然后排除过滤器。在这种情况下,选择要包含的内容,然后从包含的子集中排除的内容。

内容类型

您可以根据以下内容类型过滤内容:

表 7.2. 内容类型
内容类型Description

RPM

根据软件包的名称和版本号过滤软件包。RPM 选项会过滤非模块化 RPM 软件包和勘误表。源 RPM 不受此过滤器的影响,在内容视图中仍可用。

软件包组

根据软件包组过滤软件包。软件包组的列表基于添加到内容视图的存储库。

勘误(按 ID)

选择要添加到过滤器的特定勘误。勘误列表基于添加到内容视图的存储库。

勘误(按日期和类型)

选择要添加到过滤器的签发或更新的日期范围及勘误类型(Bugfix、Enhancement 或 Security)。

模块流

选择是否包含或排除特定模块流。Module Streams 选项过滤模块 RPM 和勘误表,但不会过滤与所选模块流关联的非模块化内容。

容器镜像标签

选择是否包含或排除特定容器镜像标签。

7.7. 解决软件包依赖项

在发布内容视图时,Satellite 可以在内容视图中添加软件包的依赖项到依赖的存储库。要配置此功能,您可以启用 依赖项解析

例如,当您逐步将单个软件包添加到内容视图版本时,依赖项会很有用。您可能需要启用依赖项,以安装该软件包。

然而,在大多数情况下,依赖项无法解决。例如:

  • 当逐步添加安全勘误到内容视图时,依赖项解决可能会导致对内容视图发布造成大量延迟,而不会造成主要好处。
  • 较新的勘误中的软件包可能会具有与旧内容视图版本中的软件包不兼容的依赖项。使用依赖项解析以递增方式添加勘误可能包括不需要的软件包。作为替代方案,请考虑更新内容视图。
注意

依赖项有助于仅考虑内容视图的存储库中的软件包。它不考虑客户端上安装的软件包。例如,如果内容视图仅包含 AppStream,依赖项需要包括在发布时不包含依赖 BaseOS 内容。

如需更多信息,请参阅管理内容中的 对存储库依赖解析的限制

依赖项解决可能会导致以下问题:

内容视图发布中的显著延迟

Satellite 会在内容视图中针对依赖项检查每个存储库。因此,发布时间会增加存储库。

要缓解这个问题,请使用带有较少存储库的多个内容视图,并将它们合并到复合内容视图中。

忽略依赖软件包的内容视图过滤器

Satellite 优先选择根据过滤器中的规则解析软件包依赖项。

例如,如果您为安全目的创建过滤器,但启用依赖项解析,Satellite 您可以添加可能认为不安全的软件包。

要缓解这个问题,请仔细测试过滤规则以确定所需的依赖项。如果依赖项解决包括不需要的软件包,请手动识别额外的软件包和勘误所需的核心基本依赖项。

例 7.1. 将排除过滤器与依赖项解决合并

您需要使用 Content View 过滤器重新创建 Red Hat Enterprise Linux 8.3,并包括后续 Red Hat Enterprise Linux 8 次版本中的所选勘误。要做到这一点,您可以在 Red Hat Enterprise Linux 8.3 发行日期后创建过滤器来排除大多数勘误,除了几个您需要的。然后,您可以实现依赖项解决。

在这种情况下,依赖项解决可能会包括比预期更多的软件包。因此,主机被认为是 Red Hat Enterprise Linux 8.3 机器。

如果您不需要额外的勘误表和软件包,请不要配置内容视图过滤。反之,在 Satellite Web UI 中的 Content > Red Hat Repositories 页面中启用并使用 Red Hat Enterprise Linux 8.3 软件仓库。

例 7.2. 排除软件包有时会使 DNF 无法进行依赖项解决

如果您制作带有一些排除的软件包的 Red Hat Enterprise Linux 8.3 软件仓库,dnf update 有时可能会失败。

不要启用依赖项来解决问题。相反,应调查 dnf 中的错误,并调整过滤器以停止排除缺少的依赖项。

否则,依赖项解决可能会导致存储库从 Red Hat Enterprise Linux 8.3 分离。

7.8. 为内容视图启用依赖解析

使用这个流程启用对内容视图的依赖项。

前提条件

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views
  2. 从内容视图列表中,选择所需的内容视图。
  3. Details 标签页中,切换 Solve 依赖项

7.9. 内容过滤器示例

将以下示例用于构建自定义内容过滤器的步骤。

注意

过滤器可能会显著增加发布内容视图的时间。例如,如果内容视图发布任务在短短几分钟内完成,则添加 exclude 或 include 勘误过滤器后可能需要 30 分钟。

示例 1

使用基本 Red Hat Enterprise Linux 软件包创建存储库。此过滤器要求将 Red Hat Enterprise Linux 存储库添加到内容视图中。

Filter:

  • 包含类型 : Include
  • 内容类型: 软件包组
  • filter: 只选择 Base 软件包组

示例 2

创建在特定日期之后,用来排除所有勘误(除安全更新外)的存储库。如果您要定期执行系统更新,但关键安全更新除外,该更新必须立即应用,这将非常有用。此过滤器要求将 Red Hat Enterprise Linux 存储库添加到内容视图中。

Filter:

  • 包含类型 : Exclude
  • 内容类型: 勘误(按日期和类型)
  • 过滤器 : 仅选择 bugfixEnhancement 勘误表类型,并清除 安全勘误 类型。将 日期类型设置为 Updated On。将 起始日期 设置为您要限制勘误的日期。将 结束日期 留空,以确保过滤任何新的非安全勘误。

示例 3

示例 1 和示例 2 的组合,其中您只需要操作系统软件包并希望排除最新的程序错误修复和增强勘误。这需要两个过滤器附加到同一内容视图。内容视图首先处理 Include 过滤器,然后处理 Exclude 过滤器。

过滤 1:

  • 包含类型 : Include
  • 内容类型: 软件包组
  • filter: 只选择 Base 软件包组

过滤器 2:

  • 包含类型 : Exclude
  • 内容类型: 勘误(按日期和类型)
  • 过滤器 : 仅选择 bugfixEnhancement 勘误表类型,并清除 安全勘误 类型。将 日期类型设置为 Updated On。将 起始日期 设置为您要限制勘误的日期。将 结束日期 留空,以确保过滤任何新的非安全勘误。

示例 4

在内容视图中过滤特定的模块流。

过滤 1:

  • 包含类型 : Include
  • 内容类型: 模块流
  • Filter : 仅选择您想要用于内容视图的特定模块流,如 ant,然后单击 Add Module Stream

过滤器 2:

  • 包含类型 : Exclude
  • 内容类型: 软件包
  • filter :添加一个规则来过滤 您要从内容视图中排除的任何非模块化软件包。如果您没有过滤软件包,Content View 过滤器会包括与模块流 ant 关联的所有非模块化软件包。添加一条规则来排除所有 * 软件包,或者指定您要排除的软件包名称。

有关内容过滤器如何工作的另一个示例,请参阅以下文章 :"如何在 Satellite 6 中工作内容过滤器 "。

7.10. 为 Yum 内容创建内容过滤器

您可以过滤包含 Yum 内容的内容视图,以包含或排除特定的软件包、软件包组、勘误表或模块流。过滤器基于 名称版本架构 的组合。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

有关如何构建过滤器的示例,请参考 第 7.9 节 “内容过滤器示例”

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views 并选择 Content View。
  2. Filters 选项卡上,单击 Create filter
  3. 输入名称。
  4. Content type 列表中,选择内容类型。
  5. Inclusion Type 列表中,选择 Include filterExclude filter
  6. 可选:在 Description 字段中输入过滤器的描述。
  7. Create filter 创建内容过滤器。
  8. 根据您为 Content Type 输入的内容,添加规则来创建您想要的过滤器。
  9. 如果您希望过滤器应用到 存储库子集, 或者 应用到所有存储库
  10. 单击 Publish New Version,以发布过滤的存储库。
  11. 可选:在 Description 字段中输入更改描述。
  12. 单击 Create filter 以发布内容视图的新版本。

    您可以在所有环境中提升此内容视图。

CLI 过程

  1. 向内容视图添加过滤器。使用 --inclusion false 选项将过滤器设置为 Exclude 过滤器:

    # hammer content-view filter create \
    --name "Errata Filter" \
    --type erratum --content-view "Example_Content_View" \
    --description "My latest filter" \
    --inclusion false \
    --organization "My_Organization"
  2. 在过滤器中添加规则:

    # hammer content-view filter rule create \
    --content-view "Example_Content_View" \
    --content-view-filter "Errata Filter" \
    --start-date "YYYY-MM-DD" \
    --types enhancement,bugfix \
    --date-type updated \
    --organization "My_Organization"
  3. 发布内容视图:

    # hammer content-view publish \
    --name "Example_Content_View" \
    --description "Adding errata filter" \
    --organization "My_Organization"
  4. 在所有环境中提升视图:

    # hammer content-view version promote \
    --content-view "Example_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Development" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Example_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Testing" \
    --organization "My_Organization"
    # hammer content-view version promote \
    --content-view "Example_Content_View" \
    --version 1 \
    --to-lifecycle-environment "Production" \
    --organization "My_Organization"

7.11. 删除多个内容视图版本

您可以同时删除多个内容视图版本。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views
  2. 选择您要删除版本的内容视图。
  3. Versions 选项卡上,选中您要删除的版本或版本的复选框。
  4. 单击内容视图列表顶部的垂直 ellipsis 图标。
  5. Delete 打开删除向导来显示任何受影响的环境。
  6. 如果没有受影响的环境,请检查详情并点 Delete
  7. 如果有受影响的环境,请在删除前重新分配任何主机或激活码。
  8. 检查操作的详情。
  9. Delete

7.12. 清除搜索过滤器

如果您使用搜索文本框中的关键字搜索特定的内容类型,且搜索不会返回任何结果,请点击 Clear search 以清除所有搜索查询并重置 搜索 文本框。

如果您使用过滤器在 Type 文本框中搜索特定存储库,且搜索返回没有结果,请点击 Clear filters 来清除所有活跃的过滤器并重置 Type 文本框中。

7.13. 标准化内容视图 Empty 状态

如果没有为内容视图列出过滤器,点 Create filter。此时会打开一个模态,以显示创建过滤器的下一步。按照以下步骤添加新过滤器来创建新内容类型。

7.14. 比较内容视图版本

使用这个流程比较 Satellite 的 Content View Version 功能。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views
  2. 选择您要比较其版本的内容视图。
  3. Versions 选项卡上,选中您要比较的两个版本旁边的复选框。
  4. 单击 Compare

    Compare 屏幕在版本下拉菜单中带有预先选择的版本,以及任一版本中找到的所有内容类型的选项卡。您可以过滤结果,使其仅显示相同、不同或所有内容类型。您可以从下拉菜单选择不同的内容视图版本来比较不同的内容视图版本。

7.15. 分发归档的内容视图版本

设置 Distribute 归档的内容视图版本 允许托管 Satellite 内容 Web 应用中的非升级内容视图版本存储库,以及其他存储库。这在调试时非常有用,以查看您的内容视图版本中存在什么内容。

流程

  1. 在 Satellite Web UI 中,导航到 Administer > Settings
  2. 单击 内容选项卡
  3. Distribute 归档的内容视图版本 参数设为 Yes
  4. Submit

    这可让没有生命周期环境的内容视图存储库分布到 satellite.example.com/pulp/content/My_Organization/content_views/My_Content_View/My_Content_View_Version/

    注意

    启用设置后,旧的非升级内容视图版本不会被分发。只有新的内容视图版本才会被分发。

第 8 章 在 Satellite 服务器之间同步内容

在与多个 Satellite 服务器的 Satellite 设置中,您可以使用卫星同步(ISS)将内容从一个上游服务器同步到一个或多个下游服务器。

根据您部署基础架构的方式,可以有两种 Satellite 配置。根据您的用例场景,为 ISS 配置 Satellite。如需更多信息,请参阅 在断开连接的网络环境中安装 Satellite 服务器中的如何配置 Inter-Satellite 同步。要更改 pulp 导出路径,请参阅 知识库文章 Hammer 内容导出失败,并带有 "Path '/the/path' is not an allowed export path "。

8.1. 如何使用导出和导入来同步内容

使用导出和导入工作流有多种方法同步内容:

  • 您可以使用上游 Satellite 服务器作为内容存储,这意味着您可以同步整个库而不是内容视图版本。此方法提供最简单的导出/导入工作流。在这种情况下,您可以管理下游的版本。更多信息请参阅 第 8.1.1 节 “使用上游 Satellite 服务器作为内容存储”
  • 您可以使用上游卫星服务器来同步内容视图版本。此方法可以更好地控制卫星服务器之间同步的内容。更多信息请参阅 第 8.1.2 节 “使用上游卫星服务器同步内容视图版本”
  • 您同步单个存储库。如果您使用 Content-View sync 方法,但这很有用,但您想要同步额外的存储库,而无需将其添加到现有内容视图中。更多信息请参阅 第 8.1.3 节 “同步单个存储库”

    注意

    使用导出和导入同步内容需要在下游和上游 Satellite 服务器上具有相同的主版本、次版本和补丁版本。

    当您无法匹配上游和下游 Satellite 版本时,您可以使用:

    • 可同步的导出和导入。
    • 通过上游 Satellite 与上游 Satellite 进行间同步(ISS),以及连接到上游 Satellite 的下游 Satellite。

8.1.1. 使用上游 Satellite 服务器作为内容存储

在这种情况下,您将使用上游卫星服务器作为更新内容存储,而不是管理内容。您可以使用下游 Satellite 服务器管理隔离网络后面的所有基础架构的内容。您可以从上游卫星服务器导出库内容,并将它导入到下游卫星服务器。

在上游卫星服务器上

  1. 确保软件仓库使用以下方法之一使用 Immediate 下载策略:

    1. 对于使用 On Demand 的现有存储库,请将存储库详情页面中的下载策略更改为 Immediate
    2. 对于新存储库,请确保在启用红帽存储库前将 Default Red Hat Repository download 策略设置为 Immediate,并且 Default 下载 策略被设置为自定义存储库的 Immediate

    更多信息请参阅 第 5.8 节 “下载策略概述”

  2. 启用您要同步的内容。更多信息请参阅 第 5.5 节 “启用红帽存储库”

    如果要同步自定义内容,首先创建自定义产品 并同步产品存储库

  3. 同步启用的内容:

    1. 在第一个导出中,执行完整的 库导出,以便导出所有同步的内容。这会生成稍后导入到一个或多个下游 Satellite 服务器的内容存档。有关执行完整的库导出的详情,请参考 第 8.3 节 “导出库环境”
    2. 在上游卫星服务器上逐步导出所有将来的更新。这会生成仅包含最新更新集合的更精简的内容存档。例如,如果您启用并同步新存储库,下一个导出的内容存档仅包含新启用的存储库的内容。有关执行增量库导出的更多信息,请参阅 第 8.6 节 “以增加方式导出库环境”

在下游卫星服务器上

  1. 将从上游卫星服务器导出的内容开启到硬盘上。
  2. 将它放到 /var/lib/pulp/imports 下的目录中。
  3. 使用 第 8.17 节 “导入到库环境中” 中介绍的步骤将内容导入到机构。

    然后,您可以根据需要使用内容视图或生命周期环境来管理内容。

8.1.2. 使用上游卫星服务器同步内容视图版本

在这种情况下,您不仅使用上游卫星服务器作为内容存储,还用于同步隔离网络后面的所有基础架构的内容。您将来自 CDN 的更新策展到内容视图和生命周期环境中。将内容提升到指定的生命周期环境后,您可以从上游 Satellite 服务器中导出内容并将其导入到下游卫星服务器中。

在上游卫星服务器上

  1. 确保软件仓库使用以下方法之一使用 Immediate 下载策略:

    1. 对于使用 On Demand 的现有存储库,请将存储库详情页面中的下载策略更改为 Immediate
    2. 对于新存储库,请确保在启用红帽存储库前将 Default Red Hat Repository download 策略设置为 Immediate,并且 Default 下载 策略被设置为自定义存储库的 Immediate

    更多信息请参阅 第 5.8 节 “下载策略概述”

  2. 启用您要同步的内容。更多信息请参阅 第 5.5 节 “启用红帽存储库”

    如果要同步自定义内容,首先创建自定义产品 并同步产品存储库

  3. 同步启用的内容:

    1. 对于第一个导出,在要导出的内容视图版本上执行 完整的 版本导出。如需更多信息,请参阅 第 8.8 节 “导出内容视图版本”。这会生成您可以导入到一个或多个下游 Satellite 服务器的内容存档。
    2. 逐步导出连接的 Satellite 服务器中所有更新。这会生成包含仅来自最新更新集合的更改的内容存档。例如,如果您的内容视图具有新存储库,此导出的内容存档仅包含最新的更改。如需更多信息,请参阅 第 8.10 节 “以增加方式导出内容视图版本”
    3. 有新内容时,在导出递增前重新发布包含此内容的内容视图。更多信息请参阅 第 7 章 管理内容视图。这会创建一个新的内容视图版本,其中包含要导出的适当内容。

在下游卫星服务器上

  1. 将从上游卫星服务器导出的内容开启到硬盘上。
  2. 将它放到 /var/lib/pulp/imports 下的目录中。
  3. 将内容导入到您想要的组织。更多信息请参阅 第 8.19 节 “导入内容视图版本”。这将从导出的内容存档中创建内容视图版本,然后相应地导入内容。

8.1.3. 同步单个存储库

在这种情况下,您可以导出和导入单个存储库。

在上游卫星服务器上

  1. 确保存储库以以下一种方式使用 Immediate 下载策略:

    1. 对于使用 On Demand 的现有存储库,请将存储库详情页面中的下载策略更改为 Immediate
    2. 对于新存储库,请确保在启用红帽存储库前将 Default Red Hat Repository download 策略设置为 Immediate,并且 Default 下载 策略被设置为自定义存储库的 Immediate

    更多信息请参阅 第 5.8 节 “下载策略概述”

  2. 启用您要同步的内容。更多信息请参阅 第 5.5 节 “启用红帽存储库”

    如果要同步自定义内容,首先创建自定义产品 并同步产品存储库

  3. 同步启用的内容:

    1. 在第一个导出中,执行完整的 存储库导出,以便导出所有同步的内容。这会生成稍后导入到一个或多个下游 Satellite 服务器的内容存档。有关执行完整的存储库导出的详情,请参考 第 8.12 节 “导出存储库”
    2. 在上游卫星服务器上逐步导出所有将来的更新。这会生成仅包含最新更新集合的更精简的内容存档。有关执行增量存储库导出的详情,请参考 第 8.14 节 “以增加方式导出存储库”

在下游卫星服务器上

  1. 将从上游卫星服务器导出的内容开启到硬盘上。
  2. 将它放到 /var/lib/pulp/imports 下的目录中。
  3. 将内容导入到组织。请参阅 第 8.21 节 “导入存储库”

    然后,您可以根据需要使用内容视图或生命周期环境来管理内容。

8.2. 同步自定义存储库

在使用 Satellite 同步网络同步时,会自动配置红帽存储库,但不会自定义存储库。使用这个流程,通过 Satellite 同步(ISS)网络同步,将连接的 Satellite 服务器上的自定义存储库的内容同步到断开连接的 Satellite 服务器。

在完成断开连接的 Satellite 服务器的步骤前,请遵循连接的 Satellite 服务器的步骤。

连接的 Satellite 服务器

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 点自定义产品。
  3. 点自定义存储库。
  4. 复制 Published At: URL。
  5. 在断开连接的 Satellite 服务器上继续操作。

断开连接的 Satellite 服务器

  1. 从连接的 Satellite 服务器下载 katello-server-ca.crt 文件:

    # curl http://satellite.example.com/pub/katello-server-ca.crt
  2. 创建一个 SSL 内容凭据,其内容为 katello-server-ca.crt。有关创建 SSL 内容凭证的详情,请参考 第 5.2 节 “导入自定义 SSL 证书”
  3. 在 Satellite Web UI 中,导航到 Content > Products
  4. 使用以下方法创建自定义产品:

    • 上游 URL :粘贴您之前复制的链接。
    • SSL CA 认证 :选择从您连接的 Satellite 服务器传输的 SSL 证书。

    有关创建自定义产品的更多信息,请参阅 第 5.3 节 “创建自定义产品”

完成这些步骤后,断开连接的 Satellite 服务器上正确配置了自定义存储库。

8.3. 导出库环境

您可以将组织的 Library 环境中所有 Yum 存储库的内容导出到卫星服务器的存档文件,并使用此存档文件在其他卫星服务器或其他卫星服务器组织中创建相同的存储库。导出的归档文件包含以下数据:

  • 包含内容视图版本元数据的 JSON 文件。
  • 包含组织库环境中所有存储库的存档文件。

Satellite 服务器仅导出库环境中所含的 RPM、Kickstart 文件和 Docker 内容。

前提条件

要导出机构的 Library 生命周期环境的内容,请确保要导出的 Satellite 服务器满足以下条件:

  • 确保导出目录具有空闲的存储空间来容纳导出。
  • 确保 /var/lib/pulp/exports 目录具有与为导出过程中创建的临时文件导出的存储库大小的空闲存储空间。
  • 确保为您导出的库生命周期环境中的所有存储库将下载策略设置为 Immediate。更多信息请参阅 第 5.8 节 “下载策略概述”
  • 确保您将导出的产品同步到所需的日期。

导出组织的库内容

  1. 使用组织名称或 ID 导出。

    # hammer content-export complete library --organization="My_Organization"
  2. 验证包含内容视图导出的版本的存档是否在导出目录中:

    # ls -lh /var/lib/pulp/exports/My_Organization/Export-Library/1.0/2021-03-02T03-35-24-00-00
    total 68M
    -rw-r--r--. 1 pulp pulp 68M Mar  2 03:35 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335.tar.gz
    -rw-r--r--. 1 pulp pulp 333 Mar  2 03:35 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335-toc.json
    -rw-r--r--. 1 pulp pulp 443 Mar  2 03:35 metadata.json

    您需要所有三个文件、tar.gztoc.jsonmetadata.json 文件才能导入。

  3. 在组织中创建新的内容视图 Export-Library。此内容视图包含属于此机构的所有存储库。此内容视图的新版本会自动发布并导出。

使用块导出

在很多情况下,导出的归档内容的大小可能为几 GB。如果您要将其分成较小的大小或块。您可以在 export 命令中直接使用 --chunk-size-gb 标志来处理这种情况。在以下示例中,您可以看到如何指定 --chunk-size-gb=22 GB 块分割存档。

# hammer content-export complete library \
--chunk-size-gb=2 \
--organization="My_Organization"

Generated /var/lib/pulp/exports/My_Organization/Export-Library/2.0/2021-03-02T04-01-25-00-00/metadata.json

# ls -lh /var/lib/pulp/exports/My_Organization/Export-Library/2.0/2021-03-02T04-01-25-00-00/

8.4. 以可同步格式导出库环境

您可以将机构库环境中所有 yum 存储库、Kickstart 存储库和文件存储库的内容导出到可同步的格式,您可以使用该格式创建自定义 CDN,并通过 HTTP/HTTPS 同步自定义 CDN 的内容。

然后,您可以在本地 Web 服务器上提供生成的内容,并在导入 Satellite 服务器或另一个 Satellite Server 组织中同步它。

您可以使用生成的内容在另一个 Satellite 服务器或使用内容导入功能在另一个 Satellite Server 组织中创建相同的存储库。在导入导出的存档时,会在导入 Satellite 服务器上创建或更新常规内容视图。更多信息请参阅 第 8.19 节 “导入内容视图版本”

您可以以同步格式从 Satellite 服务器导出以下内容:

  • yum 软件仓库
  • Kickstart 软件仓库
  • 文件软件仓库

您无法导出 Ansible、Deb 或 Docker 内容。

导出中包含有软件包的目录,以 Yum 格式 列出 存储库的文件和元数据,它们可用于在导入卫星服务器中同步。

前提条件

  • 确保将您导出的所有存储库的下载策略设置为 Immediate。更多信息请参阅 第 5.8 节 “下载策略概述”
  • 确保您将导出的产品同步到所需的日期。
  • 确保导出内容的用户具有内容 导出器 角色。

流程

  1. 使用机构名称或 ID 导出:

    # hammer content-export complete library \
    --organization="My_Organization" \
    --format=syncable
  2. 可选:验证导出的内容位于导出目录中:

    # du -sh /var/lib/pulp/exports/My_Organization/Export-My_Repository/1.0/2021-03-02T03-35-24-00-00

8.5. 导入可同步导出

流程

  • 使用机构名称或 ID 导入可同步导出:

    # hammer content-import library
    --organization="My_Organization"
    --path="My_Path_To_Syncable_Export"
注意

同步导出必须位于 /etc/pulp/settings.py 中指定的 ALLOWED_IMPORT_PATHS 中。默认情况下,这包括 /var/lib/pulp/imports

8.6. 以增加方式导出库环境

在系统资源方面,导出库内容可能会是一个非常昂贵的操作。具有多个 Red Hat Enterprise Linux 树的组织可以占用卫星服务器上的数 GB 空间。

在这种情况下,您可以使用 Incremental Export 来导出自上导出以来更改的内容片段。增量导出通常会导致存档文件比完整导出小。

以下示例显示了组织库中所有存储库的递增导出。

流程

  1. 创建增量导出:

    # hammer content-export incremental library --organization="My_Organization"
    
    Generated /var/lib/pulp/exports/My_Organization/Export-Library/3.0/2021-03-02T04-22-14-00-00/metadata.json
  2. 可选:查看导出的数据:

    # ls -lh /var/lib/pulp/exports/My_Organization/Export-Library/3.0/2021-03-02T04-22-14-00-00/
    total 172K
    -rw-r--r--. 1 pulp pulp 161K Mar  2 04:22 export-436882d8-de5a-48e9-a30a-17169318f908-20210302_0422.tar.gz
    -rw-r--r--. 1 pulp pulp  333 Mar  2 04:22 export-436882d8-de5a-48e9-a30a-17169318f908-20210302_0422-toc.json
    -rw-r--r--. 1 pulp pulp  492 Mar  2 04:22 metadata.json

8.7. 以可同步格式导出库环境

在系统资源方面,导出库内容可能是一个非常昂贵的操作。具有多个 Red Hat Enterprise Linux 树的组织可以占用卫星服务器上的数 GB 空间。

在这种情况下,您可以使用 Incremental Export 来导出自上导出以来更改的内容片段。增量导出通常会导致存档文件比完整导出要小。

以下流程显示了组织库中所有存储库的增量导出。

流程

  1. 创建增量导出:

    # hammer content-export incremental library \
    --format=syncable \
    --organization="My_Organization"
  2. 可选:查看导出的数据:

    # find /var/lib/pulp/exports/Default_Organization/Export-Library-SYNCABLE/2.0/2023-03-09T10-55-48-05-00/ -name "*.rpm"

8.8. 导出内容视图版本

您可以从卫星服务器将内容视图版本导出到存档文件,并使用此存档文件在其他卫星服务器或其他卫星服务器组织上创建相同的内容视图版本。卫星将复合内容视图导出为普通内容视图。复合性质不保留。在导入导出的存档时,会在您的下游卫星服务器上创建或更新常规内容视图。导出的归档文件包含以下数据:

  • 包含内容视图版本元数据的 JSON 文件
  • 包含内容视图版本中包含的所有存储库的存档文件

Satellite 服务器仅导出添加到内容视图版本的 RPM、Kickstart 文件和 Docker 内容。Satellite 不导出以下内容:

  • 内容视图定义和元数据,如软件包过滤器。

前提条件

要导出内容视图,请确保要导出的 Satellite 服务器满足以下条件:

  • 确保导出目录具有空闲的存储空间来容纳导出。
  • 确保 /var/lib/pulp/exports 目录具有与为导出过程中创建的临时文件导出的存储库大小的空闲存储空间。
  • 确保为您导出的内容视图内所有存储库的下载策略设置为 Immediate。更多信息请参阅 第 5.8 节 “下载策略概述”
  • 确保您将导出的产品同步到所需的日期。
  • 确保导出内容的用户具有内容 导出器 角色。

导出内容视图版本

  1. 列出可用于导出的内容视图的版本:

    # hammer content-view version list \
    --content-view="My_Content_View" \
    --organization="My_Organization"
    
    ---|----------|---------|-------------|-----------------------
    ID | NAME     | VERSION | DESCRIPTION | LIFECYCLE ENVIRONMENTS
    ---|----------|---------|-------------|-----------------------
    5  | view 3.0 | 3.0     |             | Library
    4  | view 2.0 | 2.0     |             |
    3  | view 1.0 | 1.0     |             |
    ---|----------|---------|-------------|----------------------

导出内容视图版本

  1. 获取所需版本的版本号。以下示例目标版本 1.0 用于导出。

    # hammer content-export complete version \
    --content-view="Content_View_Name" \
    --version=1.0 \
    --organization="My_Organization"
  2. 验证包含内容视图导出的版本的存档是否在导出目录中:

    # ls -lh /var/lib/pulp/exports/My_Organization/Content_View_Name/1.0/2021-02-25T18-59-26-00-00/

您需要所有三个文件,如 tar.gz 归档文件、toc.jsonmetadata.json 才能成功导入内容。

使用块导出

在很多情况下,导出的归档内容的大小可能会有多个 GB。您可能希望分割它较小的大小或块。您可以将 --chunk-size-gb 选项与 hammer content-export 命令一起使用。以下示例使用 --chunk-size-gb=2 将存档分成 2 GB 块。

# hammer content-export complete version \
--chunk-size-gb=2 \
--content-view="Content_View_Name" \
--organization="My_Organization" \
--version=1.0
# ls -lh /var/lib/pulp/exports/My_Organization/view/1.0/2021-02-25T21-15-22-00-00/

8.9. 以可同步格式导出内容视图版本

您可以将内容视图的版本导出到可用于创建自定义 CDN 的可同步格式。导出内容视图后,您可以执行以下操作之一:

  • 通过 HTTP/HTTPS 同步自定义 CDN 的内容。
  • 使用 hammer 内容导入内容。请注意,这需要导出和导入服务器来运行 Satellite 6.13。

然后,您可以使用导入的 Satellite Server 或另一个 Satellite Server 组织中的本地 Web 服务器提供生成的内容。

您无法直接导入可同步格式导出。相反,在导入 Satellite 服务器上,您必须:

  • 将生成的内容复制到可访问导入卫星服务器的 HTTP/HTTPS Web 服务器。
  • 将 CDN 配置更新为 Custom CDN
  • 将 CDN URL 设置为指向 Web 服务器。
  • 可选:如果 web 服务器需要它,请设置 SSL/TLS CA 凭证。
  • 启用存储库。
  • 同步存储库。

您可以从 Satellite 服务器以可同步格式导出以下内容:

  • yum 软件仓库
  • Kickstart 软件仓库
  • 文件软件仓库

您无法导出 Ansible、DEB 和 Docker 内容。

导出中包含有软件包的目录,以 Yum 格式 列出 存储库的文件和元数据,它们可用于在导入卫星服务器中同步。

前提条件

  • 确保将您导出的内容视图中所有存储库的下载策略设置为 Immediate。更多信息请参阅 第 5.8 节 “下载策略概述”
  • 确保您将导出的产品同步到所需的日期。
  • 确保导出内容的用户具有内容 导出器 角色。

导出内容视图版本

  • 列出可用于导出的内容视图的版本:

    # hammer content-view version list \
    --content-view="My_Content_View" \
    --organization="My_Organization"

流程

  1. 获取所需版本的版本号。以下示例目标版本 1.0 用于导出:

    # hammer content-export complete version \
    --content-view="Content_View_Name" \
    --version=1.0 \
    --organization="My_Organization" \
    --format=syncable
  2. 可选:验证导出的内容位于导出目录中:

    # ls -lh /var/lib/pulp/exports/My_Organization/My_Content_View_Name/1.0/2021-02-25T18-59-26-00-00/

8.10. 以增加方式导出内容视图版本

在系统资源方面,导出完整版本可能是一个非常昂贵的操作。具有多个 Red Hat Enterprise Linux 树的内容视图版本可以在卫星服务器上占用数千兆字节的空间。

在这种情况下,您可以创建一个增量导出,该导出仅包含自上一次导出以来更改的部分内容。增量导出通常会导致存档文件比完整导出小。

以下示例以导出版本 2.0 为目标,因为之前导出了版本 1.0。

流程

  1. 创建增量导出:

    # hammer content-export incremental version \
    --content-view="Content_View_Name" \
    --organization="My_Organization" \
    --version=2.0 \
    --format=syncable
  2. 可选:查看导出的内容视图:

    # ls -lh /var/lib/pulp/exports/My_Organization/view/2.0/2021-02-25T21-45-34-00-00/

8.11. 以可同步格式导出内容视图版本

在系统资源方面,导出完整的内容视图版本可能是一个非常昂贵的操作。具有多个 Red Hat Enterprise Linux 树的内容视图版本可以在卫星服务器上占用数千兆字节的空间。

在这种情况下,您可以使用 Incremental Export 来导出自上导出以来更改的内容片段。增量导出通常会导致存档文件比完整导出小。

以下示例以导出版本 2.0 为目标,因为之前导出了版本 1.0。

流程

  1. 创建增量导出:

    # hammer content-export incremental version \
    --content-view="My_Content_View_Name" \
    --organization="My_Organization" \
    --version=2.0 \
    --format=syncable
  2. 可选:查看导出的内容视图:

    # find /var/lib/pulp/exports/Default_Organization/view/2.0/2023-03-02T14-19-50-05-00/ -name "*.rpm"

8.12. 导出存储库

您可以从卫星服务器在组织的 Library 环境中导出存储库的内容。您可以使用此存档文件在另一个卫星服务器或其他卫星服务器组织中创建相同的存储库。

您可以从 Satellite 服务器导出以下内容:

  • Ansible 存储库
  • Kickstart 软件仓库
  • yum 软件仓库
  • 文件软件仓库
  • Docker 内容

导出包含以下数据:

  • 两个包含存储库元数据的 JSON 文件。
  • 一个或多个包含组织库环境中存储库内容的存档文件。

您需要所有文件 tar.gztoc.jsonmetadata.json 才能导入。

前提条件

  • 确保导出目录有足够的可用空间来容纳导出。
  • 确保 /var/lib/pulp/exports 目录有足够的空闲存储空间,相当于您要导出的所有存储库的大小。
  • 确保将您导出的库生命周期环境中的存储库的下载策略设置为 Immediate。更多信息请参阅 第 5.8 节 “下载策略概述”
  • 确保您将导出的产品同步到所需的日期。

流程

  1. 使用产品名称和存储库名称导出存储库:

    # hammer content-export complete repository \
    --name="My_Repository" \
    --product="My_Product"
    注意

    导出的存档的大小取决于存储库中软件包的数量和大小。如果要将导出的存档分成块,请使用 --chunk-size-gb 参数导出存储库,以 GB 为单位的整数值来限制大小,例如 ---chunk-size-gb=2

  2. 可选:验证导出的存档位于导出目录中:

    # ls -lh /var/lib/pulp/exports/My_Organization/Export-My_Repository/1.0/2022-09-02T03-35-24-00-00/

8.13. 以可同步格式导出存储库

您可以将组织的 Library 环境中存储库的内容导出到可同步的格式,您可以使用它来创建自定义 CDN 并通过 HTTP/HTTPS 同步自定义 CDN 的内容。

然后,您可以使用导入的 Satellite Server 或另一个 Satellite Server 组织中的本地 Web 服务器提供生成的内容。

您无法直接导入可同步格式导出。相反,在导入 Satellite 服务器上,您必须:

  • 将生成的内容复制到可访问导入卫星服务器的 HTTP/HTTPS Web 服务器。
  • 将 CDN 配置更新为 Custom CDN
  • 将 CDN URL 设置为指向 Web 服务器。
  • 可选:如果 web 服务器需要它,请设置 SSL/TLS CA 凭证。
  • 启用存储库。
  • 同步存储库。

您可以从 Satellite 服务器以可同步格式导出以下内容:

  • yum 软件仓库
  • Kickstart 软件仓库
  • 文件软件仓库

您无法导出 Ansible、DEB 和 Docker 内容。

导出中包含有软件包的目录,以 Yum 格式 列出 存储库的文件和元数据,它们可用于在导入卫星服务器中同步。

前提条件

流程

  1. 使用存储库名称或 ID 导出存储库:

    # hammer content-export complete repository \
    --organization="My_Organization" \
    --product="My_Product" \
    --name="My_Repository" \
    --format=syncable
  2. 可选:验证导出的内容位于导出目录中:

    # du -sh /var/lib/pulp/exports/My_Organization/Export-My_Repository/1.0/2021-03-02T03-35-24-00-00

8.14. 以增加方式导出存储库

在系统资源方面,导出存储库的操作可能会非常昂贵。典型的 Red Hat Enterprise Linux 树可能会占用卫星服务器中的多个千兆字节空间。

在这种情况下,您可以使用 Incremental Export 来导出自上导出以来更改的内容片段。增量导出通常会导致存档文件比完整导出小。

以下示例显示了 Library 生命周期环境中存储库的增量导出。

流程

  1. 创建增量导出:

    # hammer content-export incremental repository \
     --organization="My_Organization" \
     --product="My_Product" \
     --name="My_Repository"
    
    Generated /var/lib/pulp/exports/My_Organization/Export-My_Repository/3.0/2021-03-02T03-35-24-00-00/metadata.json
  2. 可选:查看导出的数据:

    # ls -lh /var/lib/pulp/exports/My_Organization/Export-My_Repository/3.0/2021-03-02T03-35-24-00-00/
    total 172K
    -rw-r--r--. 1 pulp pulp  20M Mar  2 04:22 export-436882d8-de5a-48e9-a30a-17169318f908-20210302_0422.tar.gz
    -rw-r--r--. 1 pulp pulp  333 Mar  2 04:22 export-436882d8-de5a-48e9-a30a-17169318f908-20210302_0422-toc.json
    -rw-r--r--. 1 root root  492 Mar  2 04:22 metadata.json

8.15. 以可同步格式导出存储库

在系统资源方面,导出存储库可能是一个非常昂贵的操作。典型的 Red Hat Enterprise Linux 树可能会占用卫星服务器中的多个千兆字节空间。

在这种情况下,您可以使用 Incremental Export 来导出自上导出以来更改的内容片段。增量导出通常会导致存档文件比完整导出要小。

以下流程显示了库生命周期阶段中存储库的增量导出。

流程

  1. 创建增量导出:

    # hammer content-export incremental repository \
    --organization="My_Organization" \
    --product="My_Product" \
    --name="My_Repository" \
    --format=syncable
  2. 可选:查看导出的数据:

    # find /var/lib/pulp/exports/Default_Organization/Export-SYNCABLE-Red_Hat_Ansible_Engine_2_for_RHEL_8_x86_64_RPMs-1/2.0/2023-03-09T10-55-48-05-00/ -name "*.rpm"

8.16. 记录您的导出

Satellite 保留所有导出的记录。每次您在上游卫星服务器上导出内容时,将记录并维护导出以备将来查询。您可以使用记录来组织和管理导出,这在以递增方式导出时特别有用。

在为多个下游卫星服务器导出内容时,您还可以跟踪为特定服务器导出的内容。这有助于您跟踪导出内容并前往此位置。

在导出期间使用 --destination-server 参数来指示目标服务器。这个选项适用于所有 内容导出 操作。

跟踪库导出的目的地

  • 在导出库时指定目标服务器:

    # hammer content-export complete library \
    --destination-server=My_Downstream_Server_1 \
    --organization="My_Organization" \
    --version=1.0

跟踪内容视图导出的目标

  • 在导出内容视图版本时指定目标服务器:

    # hammer content-export complete version \
    --content-view="Content_View_Name" \
    --destination-server=My_Downstream_Server_1 \
    --organization="My_Organization" \
    --version=1.0

查询导出记录

  • 使用以下命令列出内容导出:

    # hammer content-export list --organization="My_Organization"

8.17. 导入到库环境中

您可以将导出的库内容导入到其他卫星服务器上的组织的库生命周期环境中。有关从库环境导出内容的更多信息,请参阅 第 8.3 节 “导出库环境”

前提条件

  • 导出的文件必须位于 /var/lib/pulp/imports 下的目录中。
  • 如果导出内容中存在任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入内容的用户必须具有 Content Importer 角色。

流程

  1. 将导出的文件复制到您要导入的卫星服务器上的 /var/lib/pulp/imports 的子目录。
  2. 将导入目录及其内容的所有权设置为 pulp:pulp

    # chown -R pulp:pulp /var/lib/pulp/imports/2021-03-02T03-35-24-00-00
  3. 验证是否已正确设置所有权:
# ls -lh /var/lib/pulp/imports/2021-03-02T03-35-24-00-00
total 68M
-rw-r--r--. 1 pulp pulp 68M Mar  2 04:29 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335.tar.gz
-rw-r--r--. 1 pulp pulp 333 Mar  2 04:29 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335-toc.json
-rw-r--r--. 1 pulp pulp 443 Mar  2 04:29 metadata.json
  1. 识别您要导入到的组织。
  2. 要将库内容导入到 Satellite 服务器,请输入以下命令:

    # hammer content-import library \
    --organization="My_Organization" \
    --path=/var/lib/pulp/imports/2021-03-02T03-35-24-00-00

    请注意,您必须输入完整路径 /var/lib/pulp/imports/My_Exported_Library_Dir。相对路径无法正常工作。

  3. 要验证您是否导入了 Library 内容,请检查产品和存储库的内容。目标组织中创建名为 Import-Library 的新内容视图。此内容视图用于促进库内容导入。

    默认情况下,Satellite Web UI 中不会显示此内容视图。import-Library 不直接分配到主机。相反,将您的主机分配到 默认组织视图 或其他内容视图(您通常一样)。

8.18. 从 Web 服务器导入到库环境

您可以直接从 Web 服务器将导出的库内容导入到另一个 Satellite 服务器上组织的库生命周期。有关从库环境导出内容的更多信息,请参阅 第 8.3 节 “导出库环境”

前提条件

  • 导出的文件必须采用可同步格式。
  • 导出的文件必须通过 HTTP/HTTPS 访问。
  • 如果导出内容中存在任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入内容视图版本的用户必须具有 Content Importer 角色。* .Procedure

    1. 识别您要导入到的组织。
    2. 要将库内容导入到 Satellite 服务器,请输入以下命令:

      # hammer content-import library \
      --organization="My_Organization" \
      --path=http://server.example.com/pub/exports/2021-02-25T21-15-22-00-00/

      目标组织中创建名为 Import-Library 的新内容视图。此内容视图用于促进库内容导入。

      默认情况下,Satellite Web UI 中不会显示此内容视图。import-Library 不直接分配到主机。相反,将您的主机 分配给默认机构 视图或其他内容视图。

8.19. 导入内容视图版本

您可以导入导出的内容视图版本,以在其他卫星服务器上的组织中创建具有相同内容的版本。有关导出内容视图版本的详情请参考 第 8.8 节 “导出内容视图版本”

当您导入内容视图版本时,它具有相同的主版本和次版本号,并包含与具有相同软件包和勘误表相同的存储库。如果导入组织中不存在自定义存储库、产品和内容视图,则会自动创建它们。

前提条件

  • 导出的文件必须位于 /var/lib/pulp/imports 下的目录中。
  • 如果导出内容中存在任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入 Content View 版本的用户必须具有 Content Importer 角色。

流程

  1. 将导出的文件复制到您要导入的卫星服务器上的 /var/lib/pulp/imports 的子目录。
  2. 将导入目录及其内容的所有权设置为 pulp:pulp

    # chown -R pulp:pulp /var/lib/pulp/imports/2021-02-25T21-15-22-00-00/
  3. 验证是否已正确设置所有权:

    # ls -lh /var/lib/pulp/imports/2021-02-25T21-15-22-00-00/
  4. 要将内容视图版本导入到 Satellite 服务器,请输入以下命令:

    # hammer content-import version \
    --organization=My_Organization \
    --path=/var/lib/pulp/imports/2021-02-25T21-15-22-00-00/

    请注意,您必须输入完整路径 /var/lib/pulp/imports/My_Exported_Version_Dir。相对路径无法正常工作。

  5. 要验证您是否成功导入了 Content View 版本,请列出您的机构的 Content View 版本:

    # hammer content-view version list \
    --organization-id=My_Organization_ID

8.20. 从 Web 服务器导入内容视图版本

您可以直接从 Web 服务器导入导出的内容视图版本,以便在另一个 Satellite 服务器上的机构中创建具有相同内容的版本。有关导出内容视图版本的详情请参考 第 8.8 节 “导出内容视图版本”

当您导入内容视图版本时,它具有相同的主版本和次版本号,并包含与具有相同软件包和勘误表相同的存储库。如果导入机构中不存在自定义存储库、产品和内容视图,则会自动创建自定义存储库、产品和内容视图。

前提条件

  • 导出的文件必须采用可同步格式。
  • 导出的文件必须通过 HTTP/HTTPS 访问。
  • 如果导出内容中存在任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入内容视图版本的用户必须具有 Content Importer 角色。

流程

  • 要将内容视图版本导入到 Satellite 服务器,请输入以下命令:

    # hammer content-import version \
    --organization=My_Organization_ID \
    --path=http://server.example.com/pub/exports/2021-02-25T21-15-22-00-00/

8.21. 导入存储库

您可以将导出的存储库导入到另一个卫星服务器上的组织。有关导出存储库内容的更多信息,请参阅 第 8.12 节 “导出存储库”

前提条件

  • 导出文件必须位于 /var/lib/pulp/imports 下的目录中。
  • 如果导出包含任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入内容的用户必须具有 Content Importer 角色。

流程

  1. 将导出的文件复制到您要导入的卫星服务器上的 /var/lib/pulp/imports 的子目录。
  2. 将导入目录及其内容的所有权设置为 pulp:pulp

    # chown -R pulp:pulp /var/lib/pulp/imports/2021-03-02T03-35-24-00-00
  3. 验证是否已正确设置所有权:
# ls -lh /var/lib/pulp/imports/2021-03-02T03-35-24-00-00
total 68M
-rw-r--r--. 1 pulp pulp 68M Mar  2 04:29 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335.tar.gz
-rw-r--r--. 1 pulp pulp 333 Mar  2 04:29 export-1e25417c-6d09-49d4-b9a5-23df4db3d52a-20210302_0335-toc.json
-rw-r--r--. 1 pulp pulp 443 Mar  2 04:29 metadata.json
  1. 识别您要导入到的组织。
  2. 要将存储库内容导入到 Satellite 服务器,请输入以下命令:

    # hammer content-import repository \
    --organization="My_Organization" \
    --path=/var/lib/pulp/imports/2021-03-02T03-35-24-00-00

    请注意,您必须输入完整路径 /var/lib/pulp/imports/My_Exported_Repo_Dir。相对路径无法正常工作。

  3. 要验证您导入了存储库,请检查产品和存储库的内容。

8.22. 从 Web 服务器导入存储库

您可以直接从 Web 服务器将导出的存储库导入到另一个 Satellite 服务器上的机构中。有关导出存储库内容的更多信息,请参阅 第 8.12 节 “导出存储库”

前提条件

  • 导出的文件必须采用可同步格式。
  • 导出的文件必须通过 HTTP/HTTPS 访问。
  • 如果导出包含任何红帽存储库,导入机构的清单必须包含导出中包含的产品订阅。
  • 导入 Content View 版本的用户必须具有 Content Importer 角色。

流程

  1. 选择您要导入的组织。
  2. 要将存储库导入到 Satellite 服务器,请输入以下命令:

    # hammer content-import repository \
    --organization="My_Organization" \
    --path=http://server.example.com/pub/exports/2021-02-25T21-15-22-00-00/_

8.23. 使用 Hammer CLI 导出和导入内容

表 8.1. Export
意图命令

完全导出组织的库

hammer content-export complete library --organization="My_Organization"

逐步导出组织的库(假设您已导出了之前的内容)

hammer content-export incremental library --organization="My_Organization"

完全导出内容视图版本

Hammer content-export complete version --content-view="My_Content_View" --version=1.0 --organization="My_Organization"

将提升的内容视图版本导出到 Dev 环境

Hammer content-export complete version --content-view="My_Content_View" --organization="My_Organization" --lifecycle-environment="Dev"

以较小的块导出内容视图(2-GB slabs)

Hammer content-export complete version --content-view="My_Content_View" --version=1.0 --organization="My_Organization" --chunk-size-gb=2

逐步导出内容视图版本(假设您已导出了之前的操作)

Hammer content-export 增量版本 --content-view="My_Content_View" --version=2.0 --organization="My_Organization"

完全导出存储库

Hammer content-export complete repository --product="My_Product" --name="My_Repository" --organization="My_Organization"

逐步导出存储库(假设您已导出了之前的操作)

Hammer content-export incremental repository --product="My_Product" --name="My_Repository" --organization="My_Organization"

列出导出

Hammer content-export list --content-view="My_Content_View" --organization="My_Organization"

表 8.2. Import
意图命令

导入到组织的库

Hammer content-import 库 --organization="My_Organization" --path="/var/lib/pulp/imports/My_Exported_Library_Dir"

导入到内容视图版本

Hammer content-import 版本 --organization="My_Organization" --path="/var/lib/pulp/imports/My_Exported_Version_Dir"

导入存储库

Hammer content-import repository --organization="My_Organization" --path="/var/lib/pulp/imports/My_Exported_Repo_Dir"

第 9 章 管理激活码

激活密钥提供了一种自动执行系统注册和订阅附加的方法。您可以创建多个密钥,并将它们与不同的环境和内容视图相关联。例如,您可以使用 Red Hat Enterprise Linux 工作站的订阅创建一个基本激活码,并将其与特定环境中的内容视图相关联。

重要

如果您在 Satellite 上启用了简单内容访问(SCA),则无法将订阅附加到您的激活码。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

您可以在内容主机注册过程中使用激活密钥,以提高流程的速度、简单性和一致性。请注意,只有在主机被注册时,才会使用激活码。如果对激活密钥进行了更改,则它仅适用于将来使用已修改的激活密钥注册的主机。不会对现有主机进行更改。

激活密钥可以为内容主机定义以下属性:

  • 关联的订阅和订阅附加行为
  • 可用的产品和软件仓库
  • 生命周期环境和内容视图
  • 主机集合成员资格
  • 系统目的

主机创建和注册之间的内容视图冲突

当您调配主机时,Satellite 将使用您在主机组或主机设置中设置的内容视图中的其他内容。主机注册后,激活密钥中的内容视图将覆盖主机组或主机设置的原始内容视图。然后,Satellite 将激活密钥中的 Content View 用于每个将来的任务,例如重建主机。

当您重建主机时,请确保设置要在激活密钥中使用的内容视图,而不是在主机组或主机设置中使用。

将同一激活密钥与多个内容主机搭配使用

如果包含足够订阅,您可以将相同的激活码应用到多个内容主机。但是,激活密钥仅设置内容主机的初始配置。当内容主机注册到组织时,组织的内容可以手动附加到内容主机。

在内容主机中使用多个激活码

内容主机可以与多个激活密钥关联,它们合并用来定义主机设置。如果设置冲突,则最后指定的激活密钥优先。您可以通过设置主机组参数来指定优先级顺序,如下所示:

$ hammer hostgroup set-parameter \
--hostgroup "My_Host_Group" \
--name "My_Activation_Key" \
--value "name_of_first_key", "name_of_second_key", ...

9.1. 创建激活码

您可以使用激活密钥定义在注册期间附加到主机的特定订阅集合。您添加到激活码的订阅必须在关联的内容视图中可用。

重要

如果您在 Satellite 上启用了简单内容访问(SCA),则无法将订阅附加到您的激活码。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

订阅管理器根据以下因素以不同的方式附加订阅:

  • 是否有任何与激活码关联的订阅?
  • auto-attach 选项是否已启用?
  • 对于 Red Hat Enterprise Linux 8 主机:在激活码上是否设置了系统目的?

请注意,Satellite 仅为主机上安装的产品自动附加订阅。对于默认情况下不列出在 Red Hat Enterprise Linux 上安装的产品(如扩展更新支持(EUS)订阅)的订阅,请使用指定所需订阅并禁用自动附加的订阅。

根据以前的因素,使用激活码订阅 3 个可能的情况:

  1. 自动附加订阅的激活码。

    如果未指定订阅并启用自动附加,使用激活密钥搜索主机从与激活密钥关联的内容视图提供的最佳订阅搜索。这与输入 subscription-manager --auto-attach 命令类似。对于 Red Hat Enterprise Linux 8 主机,您可以将激活码配置为在注册期间在主机上设置系统目的,以增强自动订阅附加。

  2. 激活密钥为自动附加提供自定义订阅集合。

    如果指定了订阅并启用了 auto-attach,则使用激活码的主机从激活密钥中指定的列表中选择最合适的订阅。在激活码上设置系统目的不会影响这种情况。

  3. 带有确切的订阅集合的激活码。

    如果指定了订阅并禁用 auto-attach,则使用激活密钥的主机与激活密钥中指定的所有订阅相关联。在激活码上设置系统目的不会影响这种情况。

自定义产品

如果自定义产品(通常包含不是由红帽提供的内容)被分配给一个激活码,则无论自动附加设置是什么,都始终为注册的内容主机启用此产品。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Activation keys,再点 Create Activation Key
  2. Name 字段中输入激活码。
  3. 如果要设置限制,清除 Unlimited hosts 复选框,然后在 Limit 字段中输入您可以使用激活码注册的最大系统数量。如果您希望无限主机使用激活密钥注册,请确保选中了 Unlimited Hosts 复选框。
  4. 可选:在 Description 字段中输入激活码的描述。
  5. Environment 列表中,选择要使用的环境。
  6. 内容视图 列表中,选择要使用的内容视图。如果要使用已弃用的 Katello Agent 而不是 Remote Execution,Content View 必须包含 Satellite Client 6 存储库,因为它包含 katello-agent 软件包。
  7. 如果启用了简单内容访问(SCA):

    1. Repository Sets 选项卡中,确保只启用您的 named 存储库。
  8. 如果没有启用 SCA:

    1. 单击 Subscriptions 选项卡,然后单击 Add submenu。
    2. 在之前创建的订阅下,单击之前创建的复选框。
    3. 单击 Add Selected
  9. Save
  10. 可选: 对于 Red Hat Enterprise Linux 8 主机,在 System Purpose 部分中,您可以使用系统目的配置激活码,以便在注册期间在主机上设置以增强订阅自动附加。

CLI 过程

  1. 创建激活码:

    # hammer activation-key create \
    --name "My_Activation_Key" \
    --unlimited-hosts \
    --description "Example Stack in the Development Environment" \
    --lifecycle-environment "Development" \
    --content-view "Stack" \
    --organization "My_Organization"
  2. 可选: 对于 Red Hat Enterprise Linux 8 主机,输入以下命令在注册期间在主机上配置激活码,以增强订阅自动附加。

    # hammer activation-key update \
    --organization "My_Organization" \
    --name "My_Activation_Key" \
    --service-level "Standard" \
    --purpose-usage "Development/Test" \
    --purpose-role "Red Hat Enterprise Linux Server" \
    --purpose-addons "addons"
  3. 获取订阅 ID 列表:

    # hammer subscription list --organization "My_Organization"
  4. 将 Red Hat Enterprise Linux 订阅 UUID 附加到激活码:

    # hammer activation-key add-subscription \
    --name "My_Activation_Key" \
    --subscription-id My_Subscription_ID \
    --organization "My_Organization"
  5. 列出与激活码关联的产品内容:

    1. 如果启用了简单内容访问(SCA):

      # hammer activation-key product-content \
      --content-access-mode-all true \
      --name "My_Activation_Key" \
      --organization "My_Organization"
    2. 如果没有启用 SCA:

      # hammer activation-key product-content \
      --name "My_Activation_Key" \
      --organization "My_Organization"
  6. 覆盖 Satellite 客户端 6 存储库的默认 auto-enable 状态。默认状态设置为 disabled。要启用,请输入以下命令:

    # hammer activation-key content-override \
    --name "My_Activation_Key" \
    --content-label rhel-7-server-satellite-client-6-rpms \
    --value 1 \
    --organization "My_Organization"

9.2. 使用激活码更新关联的订阅

重要

只有在 Satellite 上禁用了简单内容访问(SCA)时,这个步骤才有效。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

使用这个流程更改与激活码关联的订阅。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

请注意,对激活码的更改仅适用于更改后调配的计算机。要更新现有内容主机上的订阅,请参阅 第 3.7 节 “更新多个主机上的红帽订阅”

流程

  1. 在 Satellite Web UI 中,导航到 Content > Activation keys,然后点激活码的名称。
  2. 点击 Subscriptions 选项卡。
  3. 要删除订阅,可选中 List/Remove,然后选中要删除的订阅左侧的复选框,然后单击删除所选项。
  4. 要添加订阅,请选择 Add,然后选中要添加的订阅左侧的复选框,然后单击 Add Selected
  5. 单击 Repository Sets 选项卡,再检查存储库的状态设置。
  6. 要启用或禁用存储库,请选择存储库的复选框,然后使用 Select Action 列表更改状态。
  7. 单击 Details 选项卡,为这个激活密钥选择一个内容视图,然后单击 Save

CLI 过程

  1. 列出激活码当前包含的订阅:

    # hammer activation-key subscriptions \
    --name My_Activation_Key \
    --organization "My_Organization"
  2. 从激活码中删除所需的订阅:

    # hammer activation-key remove-subscription \
    --name "My_Activation_Key" \
    --subscription-id ff808181533518d50152354246e901aa \
    --organization "My_Organization"

    对于 --subscription-id 选项,您可以使用 UUID 或订阅的 ID。

  3. 将新订阅附加到激活码:

    # hammer activation-key add-subscription \
    --name "My_Activation_Key" \
    --subscription-id ff808181533518d50152354246e901aa \
    --organization "My_Organization"

    对于 --subscription-id 选项,您可以使用 UUID 或订阅的 ID。

  4. 列出与激活码关联的产品内容:

    # hammer activation-key product-content \
    --name "My_Activation_Key" \
    --organization "My_Organization"
  5. 覆盖所需存储库的默认 auto-enable 状态:

    # hammer activation-key content-override \
    --name "My_Activation_Key" \
    --content-label content_label \
    --value 1 \
    --organization "My_Organization"

    对于 --value 选项,输入 1 代表启用,0 代表禁用。

9.3. 为主机注册使用激活码

您可以使用激活码完成以下任务:

  • 通过 Red Hat Satellite 在置备过程中注册新主机。Red Hat Satellite 中的 kickstart 自定义模板包含使用创建主机时定义的激活密钥注册主机的命令。
  • 注册现有 Red Hat Enterprise Linux 主机。配置订阅管理器以使用卫星服务器注册,并在运行 subscription-manager register 命令时指定激活密钥。

您可以使用 Satellite Web UI、hammer CLI 或 Satellite API 中的主机注册功能,将主机注册到 Satellite。如需更多信息, 请参阅管理主机中的 注册主机

流程

  1. 在 Satellite Web UI 中,导航到 Hosts > Register Host
  2. Activation Keys 列表中,选择要分配给您的主机的激活密钥。
  3. Generate 创建注册命令。
  4. 点击 文件 图标将命令复制到您的剪贴板。
  5. 使用 SSH 连接到您的主机并运行注册命令。
  6. 检查 /etc/yum.repos.d/redhat.repo 文件,并确保启用了适当的软件仓库。

CLI 过程

  1. 使用 Hammer CLI 生成主机注册命令:

    # hammer host-registration generate-command \
    --activation-keys "My_Activation_Key"

    如果您的主机不信任 Satellite 服务器的 SSL 证书,您可以通过在 registration 命令中添加 --insecure 标志来禁用 SSL 验证。

    # hammer host-registration generate-command \
    --activation-keys "My_Activation_Key" \
    --insecure true
  2. 使用 SSH 连接到您的主机并运行注册命令。
  3. 检查 /etc/yum.repos.d/redhat.repo 文件,并确保启用了适当的软件仓库。

API 流程

  1. 使用 Satellite API 生成主机注册命令:

    # curl -X POST https://satellite.example.com/api/registration_commands \
    --user "My_User_Name" \
    -H 'Content-Type: application/json' \
    -d '{ "registration_command": { "activation_keys": ["My_Activation_Key_1, My_Activation_Key_2"] }}'

    如果您的主机不信任 Satellite 服务器的 SSL 证书,您可以通过在 registration 命令中添加 --insecure 标志来禁用 SSL 验证。

    # curl -X POST https://satellite.example.com/api/registration_commands \
    --user "My_User_Name" \
    -H 'Content-Type: application/json' \
    -d '{ "registration_command": { "activation_keys": ["My_Activation_Key_1, My_Activation_Key_2"], "insecure": true }}'

    使用激活码来简化指定环境。如需更多信息,请参阅管理内容中的管理激活码

    要将密码作为命令行参数输入,请使用 username:password 语法。请记住,这可以将密码保存在 shell 历史记录中。或者,您可以使用临时个人访问令牌而不是密码。要在 Satellite Web UI 中生成令牌,请导航到 My Account > Personal Access Tokens

  2. 使用 SSH 连接到您的主机并运行注册命令。
  3. 检查 /etc/yum.repos.d/redhat.repo 文件,并确保启用了适当的软件仓库。

多个激活码

在注册内容主机时,您可以使用多个激活码。然后,您可以为特定的订阅集合创建激活码,并根据内容主机要求进行合并。例如,以下命令将内容主机注册到您的机构中带有 VDC 和 OpenShift 订阅:

# subscription-manager register --org="My_Organization" \
--activationkey="ak-VDC,ak-OpenShift"

设置冲突

如果激活密钥中有冲突的设置,则最右侧的键将优先使用。

  • 冲突的设置: 服务级别发行版本环境内容视图,以及 产品内容
  • 不冲突的设置,主机会继承它们: 订阅和 主机集合
  • 影响密钥本身行为的设置,而不是主机配置: Content Host LimitAuto-Attach

9.4. 启用自动附加

当在激活码上启用了自动附加并且有与密钥关联的订阅时,订阅管理服务会根据一组条件(如当前安装的产品、架构和首选项)选择和附加最佳匹配的相关订阅。

重要

只有在 Satellite 上禁用了简单内容访问(SCA)时,这个步骤才有效。启用 SCA 后,您不需要将订阅附加到主机。请注意,为新创建的组织默认启用 SCA。要了解更多有关 SCA 的信息,请参阅 简单内容访问

您可以启用自动附加,且没有与密钥关联的订阅。当您不希望虚拟机使用物理订阅,但从 hypervisor 中继承基于主机的订阅时,通常使用这种密钥来注册虚拟机。如需更多信息,请参阅在 Red Hat Satellite 中配置虚拟机订阅

auto-attach 默认启用。如果要强制附加与激活码关联的所有订阅,请禁用该选项。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Activation Keys
  2. 点您要编辑的激活码名称。
  3. 点击 Subscriptions 选项卡。
  4. 单击 Auto-Attach 旁边的编辑图标。
  5. 选择或清除复选框以启用或禁用自动附加。
  6. Save

CLI 过程

  • 输入以下命令在激活码中启用自动附加:

    # hammer activation-key update --name "My_Activation_Key" \
    --organization "My_Organization" --auto-attach true

9.5. 设置服务级别

您可以配置激活码,为使用激活密钥创建的新主机定义默认服务级别。设置默认服务级别,仅选择要附加到主机的匹配订阅。例如,如果激活密钥的默认服务级别设置为 Premium,则注册后只会将具有高级服务级别的订阅附加到主机。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Activation Keys
  2. 点您要编辑的激活码名称。
  3. 单击 服务级别 旁边的编辑图标。
  4. 从列表中选择所需的服务级别。列表中仅包含可用于激活密钥的服务级别。
  5. Save

CLI 过程

  • 输入以下命令在激活码上将默认服务级别设置为 Premium :

    # hammer activation-key update --name "My_Activation_Key" \
    --organization "My_Organization" --service-level premium

9.6. 在激活码上启用和禁用存储库

使用这个流程在激活码中启用或禁用软件仓库。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Activation Keys
  2. 选择您的机构。
  3. 选择激活码。
  4. Repository set 选项卡。
  5. Select Action 菜单中,选择 Override to EnabledOverride to Disabled,以在激活码上启用或禁用存储库。

第 10 章 管理勘误

作为红帽质量控制和发行过程的一部分,我们为客户提供官方红帽 RPM 版本的更新。红帽将相关软件包组编译成 勘误 以及提供更新描述的公告。公告类型有三种(按重要程度排列):

安全公告
描述软件包中找到的固定安全问题。问题的安全影响可以是 Low、Moderate、Important 或 Critical。
错误修复公告
描述了软件包的程序错误修复。
产品增强公告
描述软件包中添加的功能增强和新功能。

当将存储库与红帽的内容交付网络(CDN)同步时,Red Hat Satellite 会导入此勘误信息。Red Hat Satellite 还提供了检查和过滤勘误表的工具,允许精确更新管理。这样,您可以选择相关的更新,并通过内容视图传播到选定的内容主机。

勘误表会根据它们包含的最重要公告类型进行标记。因此,标记为 产品功能增强公告 的勘误只能包含功能增强更新,而 程序错误修复公告 则可以包含程序错误修复和增强,而 安全公告 则可由所有三种类型组成。

在 Red Hat Satellite 中,有两个关键字来描述与可用内容主机的关系:

不适用
适用于一个或多个内容主机的勘误表,这意味着它会更新内容主机上的软件包。虽然这些勘误表应用到内容主机,直到其状态更改为可安装,但勘误无法安装。可安装的勘误自动适用。
可安装
适用于一个或多个内容主机的勘误表,可用于在内容主机上安装。可以从生命周期环境和相关内容视图,但尚未安装的内容主机,可安装勘误表。

本章介绍了如何管理勘误表并将其应用到单个主机或多个主机。

10.1. 检查可用的勘误

以下流程描述了如何查看和过滤可用的勘误以及如何显示所选公告的元数据。要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Errata 来查看可用勘误列表。
  2. 使用页面顶部的过滤工具来限制显示的勘误数:

    • 从列表中选择要检查的存储库。默认选择 所有存储库。
    • 默认选择 适用 复选框,以仅查看所选存储库中适用的勘误表。选中可安装复选框,以仅查看标记为可安装的勘误表。
    • 要搜索勘误表,在 Search 字段中以以下形式输入查询:

      parameter operator value

      有关可用于搜索的参数列表,请参阅 第 10.2 节 “可用于勘误搜索的参数”。在管理 Red Hat Satellite 中的 Granular Search 的支持的 Operator 中找到适用运算符的列表。根据您键入的自动建议。您还可以将查询与 或 或 运算符的使用结合。例如,只显示与内核软件包相关的安全公告,请输入:

      type = security and package_name = kernel

      Enter 键开始搜索。

  3. 点击您要检查的勘误的勘误 ID

    • Details 选项卡包含更新的软件包的描述以及更新提供的重要修复和增强文档。
    • Content Hosts 选项卡中,您可以将勘误应用到所选内容主机,如 第 10.9 节 “将勘误应用到多个主机” 所述。
    • Repositories 选项卡列出了已包含勘误的存储库。您可以根据环境和内容视图过滤存储库,并根据存储库名称搜索它们。

您还可以使用新的 Host 页面查看来检查可用的勘误表,并选择要安装的勘误表。

  1. 在 Satellite Web UI 中,导航到 Hosts > All Hosts 并选择您需要的主机。
  2. 如果与主机关联了勘误,则新 Host 页面中的可安装勘误卡会显示一个交互式 pie 图表,显示安全公告、错误修复和增强的分类。
  3. 在新的 Host 页面中,选择 Content 选项卡。
  4. 在 Content 页面上,选择 Errata 选项卡。
  5. 页面中显示所选主机的可安装勘误表。
  6. 单击您要安装的任何勘误的复选框。
  7. 使用您要添加到主机的勘误表旁边的垂直 ellipsis 图标,如果您无法使用 SSH 连接到目标主机,请选择 Apply via Katello agent
  8. 选择您要 自定义远程执行,选择 Apply via Remote Execution 来使用 Remote Execution,或者通过自定义远程执行应用。
  9. Submit

CLI 过程

  • 要查看所有机构都可用的勘误,请输入以下命令:

    # hammer erratum list
  • 要查看特定勘误的详情,请输入以下命令:

    # hammer erratum info --id erratum_ID
  • 您可以使用 --search 选项输入查询来搜索勘误表。例如,要查看包含排序的指定错误的所选产品的适用勘误,以便在顶部显示安全勘误,请输入以下命令:

    # hammer erratum list \
    --product-id 7 \
    --search "bug = 1213000 or bug = 1207972" \
    --errata-restrict-applicable 1 \
    --order "type desc"

10.2. 可用于勘误搜索的参数

参数DescriptionExample

bug

按照 Bugzilla 号搜索。

bug = 1172165

CVE

按照 CVE 号搜索。

cve = CVE-2015-0235

id

按照勘误表 ID 搜索。auto-suggest 系统在您输入时显示可用 ID 列表。

id = RHBA-2014:2004

发布日期

按照问题日期搜索。您可以指定具体日期,如 "Feb16,2015",或者使用关键字,如 "Yesterday" 或 "1 hour ago"。时间范围可使用 "<" 和 ">" operator 指定。

发布日期:"Jan 12,2015"

package

按照完整的软件包构建名称搜索。auto-suggest 系统在您输入时显示可用软件包列表。

package = glib2-2.22.5-6.el6.i686

package_name

按照软件包名称搜索。auto-suggest 系统在您输入时显示可用软件包列表。

package_name = glib2

严重性

按照安全更新所解决的问题的严重性搜索。指定 CriticalImportantModerate (中度)。

严重性 = Critical

title

按照公告标题搜索。

title ~ openssl

type

按照公告类型搜索。指定 安全性错误修复 或功能增强

type = bugfix

已更新

按照最后一次更新的日期搜索。您可以使用与 issued 参数相同的格式。

updated = "6 days ago"

10.3. 应用可安装的勘误

使用以下步骤查看可安装的勘误列表,并选择要安装的勘误。

流程

  1. 在 Satellite Web UI 中,导航到 Hosts > All Hosts 并选择您需要的主机。
  2. 如果存在与主机关联的勘误,则在新的 Host 页面的 Installable Errata 卡中会显示它们。
  3. Content 选项卡上,勘误 显示所选主机的可安装勘误表。
  4. 单击您要安装的任何勘误的复选框。
  5. 使用您要添加到主机的勘误表旁边的垂直 ellipsis 图标,选择 Apply via Remote Execution 来使用 Remote Execution。如果要自定义 远程执行,请选择 Apply via custom remote execution,如果无法使用 SSH 连接到目标主机,请选择 Apply via Katello 代理
  6. Submit

10.4. 订阅勘误通知

您可以为 Satellite 用户配置电子邮件通知。用户收到适用和可安装勘误表的摘要、有关内容视图提升或同步后的通知。如需更多信息,请参阅管理 Red Hat Satellite 中的 配置电子邮件通知首选项

10.5. 仓库依赖解析的限制

在卫星中,使用对内容视图的增量更新解决了一些存储库依赖项问题。但是,在仓库级别的依赖项解析仍然会在 occasion 中造成问题。

当存储库更新与新依赖项可用时,Satellite 会检索最新版本的软件包来解决依赖项,即使现有存储库软件包中有旧版本。这可在安装软件包时创建更多依赖项解决问题。

示例情境

客户端上的存储库包含软件包 example_repository-1.0,其依赖项为 example_repository-libs-1.0。存储库也具有另一个软件包 example_tools-1.0

软件包 example_tools-1.1 中提供了安全勘误。example_tools-1.1 软件包需要 example_repository-libs-1.1 软件包作为依赖项。

增量内容视图更新后,example_tools-1.1example_tools-1.0example_repository-libs-1.1 现在位于存储库中。存储库也具有软件包 example_repository-1.0example_repository-libs-1.0。请注意,对 Content View 的增量更新没有添加软件包 example_repository-1.1。因为您可以使用 yum 安装所有这些软件包,因此不会检测到潜在的问题。但是,当客户端安装 example_tools-1.1 软件包时,会发生依赖项解决问题,因为 example_repository-libs-1.0example_repository-libs-1.1 都不能安装。

当前没有解决此问题的方法。时间段越大,RPM 和所应用勘误表之间的次要 Y 版本越大,依赖项解析问题的可能性就越大。

10.6. 为勘误创建内容视图过滤器

您可以使用内容过滤器来限制勘误表。这些过滤器包括:

  • id - 选择特定的勘误以允许生成的软件仓库。
  • 日期范围 - 定义日期范围,并包括该日期范围内发布的一组勘误。
  • Type - 选择要包括的勘误类型,如错误修复、功能增强和安全更新。

创建内容过滤器,以在特定日期后排除勘误表。这样可确保应用程序生命周期中的生产系统保持最新状态。然后,您可以修改过滤器的开始日期,以在测试环境中引入新勘误表,以测试新软件包在应用程序生命周期内的兼容性。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

前提条件

流程

  1. 在 Satellite Web UI 中,导航到 Content > Content Views 并选择您要用来应用勘误表的内容视图。
  2. 选择 Yum Content > Filters,再单击 New Filter
  3. Name 字段中输入 Errata Filter
  4. Content Type 列表中,选择 Erratum - Date and Type
  5. Inclusion Type 列表中,选择 Exclude
  6. Description 字段中,输入 YYYY-MM-DD 中的 Exclude errata 项
  7. Save
  8. 对于 勘误类型,请选中您要排除的勘误表类型的复选框。例如,选中 EnhancementBugfix 复选框,并清除 Security 复选框,以在特定日期后排除功能增强和程序错误修复勘误,但包含所有安全勘误。
  9. 对于 日期类型,请选择两个复选框之一:

    • 针对 勘误的发布日期发布日期。
    • 为勘误最后一次更新的日期更新 On。
  10. 选择 Start Date 以排除在所选日期或之后的所有勘误。
  11. End Date 字段留空。
  12. Save
  13. 单击 Publish New Version 以发布生成的存储库。
  14. Description 字段中输入 Adding errata filter
  15. Save

    当内容视图完成发布时,请注意 Content 列报告了来自初始存储库的软件包和勘误表的减少数量。这意味着过滤器成功排除了上一年中的所有非安全勘误。

  16. Versions 选项卡。
  17. 单击发布的版本右侧的 Promote
  18. 选择您要提升内容视图版本的环境。
  19. Description 字段中,输入用于提升的描述。
  20. 单击 Promote Version,以在所需环境中提升此内容视图版本。

CLI 过程

  1. 为勘误创建过滤器:

    # hammer content-view filter create --name "Filter Name" \
    --description "Exclude errata items from the YYYY-MM-DD" \
    --content-view "CV Name" --organization "Default Organization" \
    --type "erratum"
  2. 创建过滤规则来排除您要设置的 开始日期或之后 的所有勘误:

    # hammer content-view filter rule create --start-date "YYYY-MM-DD" \
    --content-view "CV Name" --content-view-filter="Filter Name" \
    --organization "Default Organization" --types=security,enhancement,bugfix
  3. 发布内容视图:

    # hammer content-view publish --name "CV Name" \
    --organization "Default Organization"
  4. 将内容视图提升到 生命周期环境,以便包含的勘误表可用于该生命周期环境:

    # hammer content-view version promote \
    --content-view "CV Name" \
    --organization "Default Organization" \
    --to-lifecycle-environment "Lifecycle Environment Name"

10.7. 将勘误添加到增量内容视图

如果勘误表可用但无法安装,您可以创建一个增量内容视图版本,以将勘误表添加到您的内容主机。例如,如果 Content View 是版本 1.0,它将变为 Content View 版本 1.1,当发布时,它将变为 Content View 版本 2.0。

重要

如果您的内容视图版本旧,则增量添加增强勘误时可能会遇到不兼容的问题。这是因为增强功能通常为存储库中的最新软件设计。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Errata
  2. Errata 列表中,单击您要应用的勘误表的名称。
  3. 选择您要将勘误表应用到的内容主机,然后单击 Apply to Hosts。这会创建对内容视图的增量更新。
  4. 如果要将勘误表应用到内容主机,请在 发布复选框后马上选择应用勘误表到内容主机
  5. Confirm 以应用勘误。

CLI 过程

  1. 列出勘误及其对应的 ID:

    # hammer erratum list
  2. 列出不同的 content-view 版本和对应的 ID:

    # hammer content-view version list
  3. 将单个勘误应用到内容视图版本。您可以在用逗号分开的列表中添加更多 ID。

    # hammer content-view version incremental-update \
    --content-view-version-id 319 --errata-ids 34068b

10.8. 将勘误应用到主机

使用这些流程审核并将勘误表应用到主机。

前提条件

注意

如果主机已配置为使用已弃用的 Katello Agent 接收内容更新,请改为迁移到远程执行。如需更多信息,请参阅管理主机中的 从 Katello Agent 迁移到远程执行

将勘误应用到受管主机的步骤取决于其操作系统。

10.8.1. 将勘误应用到运行 Red Hat Enterprise Linux 9 的主机

使用这个流程查看并将勘误表应用到运行 Red Hat Enterprise Linux 9 的主机。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Hosts > Content Hosts,再选择您要将勘误表应用到的主机。
  2. 导航到 Errata 选项卡,以查看勘误表列表。
  3. 选择要应用的勘误表,然后单击 Apply Selected。在确认窗口中,单击 应用
  4. 在任务更新与所选勘误关联的所有软件包后,点 Details 选项卡查看更新的软件包。

CLI 过程

  1. 列出主机的所有勘误:

    # hammer host errata list \
    --host client.example.com
  2. 查找勘误所属的模块流:

    # hammer erratum info --id ERRATUM_ID
  3. 在主机上,更新模块流:

    # dnf update Module_Stream_Name

10.8.2. 将勘误应用到运行 Red Hat Enterprise Linux 8 的主机

使用这个流程查看并将勘误表应用到运行 Red Hat Enterprise Linux 8 的主机。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Hosts > Content Hosts,再选择您要将勘误表应用到的主机。
  2. 导航到 Errata 选项卡,以查看勘误表列表。
  3. 选择要应用的勘误表,然后单击 Apply Selected。在确认窗口中,单击 应用
  4. 在任务更新与所选勘误关联的所有软件包后,点 Details 选项卡查看更新的软件包。

CLI 过程

  1. 列出主机的所有勘误:

    # hammer host errata list \
    --host client.example.com
  2. 查找勘误所属的模块流:

    # hammer erratum info --id ERRATUM_ID
  3. 在主机上,更新模块流:

    # dnf update Module_Stream_Name

10.8.3. 将勘误应用到运行 Red Hat Enterprise Linux 7 的主机

使用这个流程查看并将勘误表应用到运行 Red Hat Enterprise Linux 7 的主机。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Hosts > Content Hosts,再选择您要将勘误表应用到的主机。
  2. 导航到 Errata 选项卡,以查看勘误表列表。
  3. 选择要应用的勘误表,然后单击 Apply Selected。在确认窗口中,单击 应用
  4. 在任务更新与所选勘误关联的所有软件包后,点 Details 选项卡查看更新的软件包。

CLI 过程

  1. 列出主机的所有勘误:

    # hammer host errata list \
    --host client.example.com
  2. 将最新的勘误应用到主机。识别使用勘误 ID 应用的勘误。

    使用 远程执行

    # hammer job-invocation create \
    --feature katello_errata_install \
    --inputs errata=ERRATUM_ID1,ERRATUM_ID2 \
    --search-query "name = client.example.com"

    使用 Katello Agent (已弃用)

    # hammer host errata apply \
    --errata-ids ERRATUM_ID1,ERRATUM_ID2... \
    --host "client.example.com"

10.9. 将勘误应用到多个主机

使用这些流程审核并将勘误表应用到多个 RHEL 主机。

前提条件

注意

如果主机已配置为使用已弃用的 Katello Agent 接收内容更新,请改为迁移到远程执行。如需更多信息,请参阅管理主机中的 从 Katello Agent 迁移到远程执行

流程

  1. 在 Satellite Web UI 中,导航到 Content > Errata
  2. 点击您要应用的勘误名称。
  3. 单击 Content Hosts 选项卡。
  4. 选择您要应用勘误表的主机,然后单击 应用到主机
  5. 单击 Confirm

CLI 过程

  1. 列出所有可安装的勘误:

    # hammer erratum list \
    --errata-restrict-installable true \
    --organization "Default Organization"
  2. 将其中一个勘误应用到多个主机:

    使用 远程执行

    # hammer job-invocation create \
    --feature katello_errata_install \
    --inputs errata=ERRATUM_ID \
    --search-query "applicable_errata = ERRATUM_ID"

    使用 Katello Agent (已弃用)

    识别您要使用的勘误,并列出这个勘误适用于的主机:

    # hammer host list \
    --search "applicable_errata = ERRATUM_ID" \
    --organization "Default Organization"

    以下 Bash 脚本对有这个勘误可用的主机都有一个勘误:

    for HOST in hammer --csv --csv-separator "|" host list --search "applicable_errata = ERRATUM_ID" --organization "Default Organization" | tail -n+2 | awk -F "|" '{ print $2 }' ;
    do
      echo "== Applying to $HOST ==" ; hammer host errata apply --host $HOST --errata-ids ERRATUM_ID1,ERRATUM_ID2 ;
    done

    此命令识别带有 errata _ID 作为适用勘误的所有主机,然后将勘误应用到每个主机。

  3. 要查看勘误是否已成功应用,请在以下命令的输出中找到对应的任务:

    # hammer task list
  4. 查看所选任务的状态:

    # hammer task progress --id task_ID

10.10. 将勘误应用到主机集合

使用 远程执行

# hammer job-invocation create \
--feature katello_errata_install \
--inputs errata=ERRATUM_ID1,ERRATUM_ID2,... \
--search-query "host_collection = HOST_COLLECTION_NAME"

使用 Katello Agent (已弃用)

# hammer host-collection erratum install \
--errata "erratum_ID1,erratum_ID2,..." \
--name "host_collection_name"\
--organization "My_Organization"

第 11 章 管理容器镜像

使用 Satellite,您可以从各种源导入容器镜像,并使用内容视图将它们分发到外部容器。

有关 Red Hat Enterprise Linux Atomic Host 7 的容器的详情,请参考 Red Hat Enterprise Linux Atomic Host 7 中的容器入门

有关 Red Hat Enterprise Linux 8 容器的详情,请参考 Red Hat Enterprise Linux 8 中构建、运行和管理容器

有关 Red Hat Enterprise Linux 9 的容器的详情,请参考 Red Hat Enterprise Linux 9 中构建、运行和管理容器

11.1. 导入容器镜像

您可以从 Red Hat Registry 或其他镜像 registry 导入容器镜像存储库。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

存储库发现过程

  1. 在 Satellite Web UI 中,导航到 Content > Products,再点 Repo Discovery
  2. Repository Type 列表,选择 Container Images
  3. Registry to Discover 字段中输入要从中导入镜像的 registry 的 URL。
  4. Registry Username 字段中,输入与容器镜像 registry 用户名对应的名称。
  5. Registry Password 字段中,输入与您输入的用户名对应的密码。
  6. Registry Search Parameter 字段中,输入您要用来过滤搜索的任何搜索条件,然后单击 Discover
  7. 可选: 要进一步优化 Discovered Repository 列表,在 Filter 字段中输入您要使用的任何其他搜索条件。
  8. Discovered Repository 列表中,选择您要导入的任何存储库,然后单击 Create Selected
  9. 可选: 要将此容器存储库的下载策略更改为 按需,请参阅 第 5.10 节 “更改存储库的下载策略”
  10. 可选: 如果要创建产品,请从 Product 列表中选择 New Product
  11. Name 字段中输入产品名称。
  12. 可选:在 Repository NameRepository Label 列中,您可以编辑存储库名称和标签。
  13. 单击 Run Repository Creation
  14. 创建存储库后,您可以点击每个新存储库来查看更多信息。
  15. 可选: 要过滤您导入到存储库的内容,点存储库,然后导航到 Limit Sync Tags。单击以编辑,并添加您要限制与 Satellite 同步内容的任何标签。
  16. 在 Satellite Web UI 中,导航到 Content > Products 并选择您的产品名称。
  17. 选择新存储库,然后单击 Sync Now 以启动同步过程。

手动创建存储库的步骤

  1. 在 Satellite Web UI 中,导航到 Content > Products。点所需产品的名称。
  2. 单击 New repository
  3. Type 列表中,选择 docker。输入存储库的详细信息,然后单击保存
  4. 选择新存储库,然后单击 Sync Now

后续步骤

  • 要查看同步的进度,请导航到 Content > Sync Status 并展开 repository tree。
  • 同步完成后,您可以点击 Container Image Manifests 列出可用的清单。从列表中,您还可以删除您不需要的任何清单。

CLI 过程

  1. 创建自定义 Red Hat Container Catalog 产品:

    # hammer product create \
    --description "My_Description" \
    --name "Red Hat Container Catalog" \
    --organization "My_Organization" \
    --sync-plan "My_Sync_Plan"
  2. 为容器镜像创建存储库:

    # hammer repository create \
    --content-type "docker" \
    --docker-upstream-name "rhel7" \
    --name "RHEL7" \
    --organization "My_Organization" \
    --product "Red Hat Container Catalog" \
    --url "http://registry.access.redhat.com/"
  3. 同步存储库:

    # hammer repository synchronize \
    --name "RHEL7" \
    --organization "My_Organization" \
    --product "Red Hat Container Catalog"

其他资源

11.2. 管理容器名称模式

当您使用 Satellite 创建和管理容器时,当容器通过 Satellite 生命周期环境的 Content View 版本和不同阶段移动容器时,容器名称会改变。例如,如果您从上游存储库将容器镜像与名称 ssh 同步,当您将其添加到 Satellite 产品和机构时,作为内容视图的一部分发布,容器镜像可以具有下列名称: my_organization_production-custom_ fluent-my_product-custom_ssh。当您要拉取容器镜像时可能会造成问题,因为容器 registry 只能包含容器名称的一个实例。为了避免 Satellite 命名约定出现问题,您可以设置 registry 名称模式来覆盖默认名称,以确保文件名明确以备将来使用。

限制

如果使用 registry 名称模式来管理容器命名约定,因为 registry 命名模式必须生成全局唯一的名称,您可能会遇到命名冲突问题。例如:

  • 如果设置 repository.docker_upstream_name registry 名称模式,则无法将带有相同存储库名称的容器内容发布或提升为 Production 生命周期。
  • 如果设置 lifecycle_environment.name registry 名称模式,这可以防止创建具有相同名称的第二个容器存储库。

为容器定义 registry 命名模式时,您必须小心。

流程

要使用 registry 名称模式管理容器命名,请完成以下步骤:

  1. 在 Satellite Web UI 中,导航到 Content > Lifecycle Environments,并创建 执行环境,或选择要编辑的生命周期阶段。
  2. Container Image Registry 区域中,单击 Registry Name Pattern 区域右侧的编辑图标。
  3. 使用变量和示例列表来确定您需要的注册表名称模式。
  4. Registry Name Pattern 字段中输入您要使用的 registry 名称模式。例如,要使用 repository.docker_upstream_name

    <%= repository.docker_upstream_name %>
  5. Save

11.3. 管理容器 Registry 身份验证

您可以管理从 Satellite 访问容器镜像的身份验证设置。默认情况下,用户必须进行身份验证以访问卫星中的容器镜像。

您可以指定是否要进行身份验证以在生命周期环境中访问 Satellite 中的容器镜像。例如,您可能希望允许用户从 Production 生命周期访问容器镜像,无需身份验证要求,并将 DevelopmentQA 环境的访问权限限制为经过身份验证的用户。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Lifecycle Environments
  2. 选择您要为其管理身份验证的生命周期环境。
  3. 要允许未经身份验证访问此生命周期环境中的容器,请选择未验证的 Pull 复选框。要限制未经身份验证的访问,请清除 未验证的 Pull 复选框。
  4. Save

11.4. 配置 Podman 和 Docker 以信任证书颁发机构

Podman 使用两个路径来查找 CA 文件,即 /etc/containers/certs.d//etc/docker/certs.d/

将 root CA 文件复制到其中一个位置,使用由服务器主机名决定的确切路径,并将文件命名为 ca.crt

在以下示例中,根据您的用例,将 hostname.example.com 替换为 satellite. example.com 或 Capsule.example.com。

  • 您首先需要使用以下方法创建相关位置:

    # mkdir -p /etc/containers/certs.d/hostname.example.com

    或者

    # mkdir -p /etc/docker/certs.d/hostname.example.com
  • 对于 podman,请使用:

    # cp rootCA.pem /etc/containers/certs.d/hostname.example.com/ca.crt
  • 或者,如果您使用 Docker,将 root CA 文件复制到等同的 Docker 目录中:

    # cp rootCA.pem /etc/docker/certs.d/hostname.example.com/ca.crt

登录到 registry 时,不再需要使用 --tls-verify=false 选项:

$ podman login hostname.example.com

Username: admin
Password:
Login Succeeded!

11.5. 使用容器 registry

Podman 和 Docker 可用于从容器 registry 获取内容。

胶囊上的容器 registry

在带有内容的胶囊上,Container Gateway Capsule 插件充当容器 registry。它将来自 Katello 的身份验证信息并将传入请求代理到 Pulp。容器网关默认在带有内容的胶囊上可用。

流程

登录到容器 registry:

# podman login satellite.example.com

列出容器镜像:

# podman search satellite.example.com/

拉取容器镜像:

# podman pull satellite.example.com/my-image:<optional_tag>

第 12 章 管理 ISO 镜像

您可以使用 Satellite 存储 ISO 镜像,可以是来自红帽的 Content Delivery Network 或其他源。您还可以上传其他文件,如虚拟机镜像,并将它们发布到存储库中。

12.1. 从红帽导入 ISO 镜像

Red Hat Content Delivery Network 为某些产品提供 ISO 镜像。导入此内容的步骤与为 RPM 内容启用存储库的步骤类似。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Red Hat Repositories
  2. Search 字段中,输入镜像名称,例如 Red Hat Enterprise Linux 7 Server (ISO)
  3. 在 Available Repositories 窗口中,展开 Red Hat Enterprise Linux 7 Server (ISO)
  4. 对于 x86_64 7.2 条目,点 Enable 图标为镜像启用存储库。
  5. 在 Satellite Web UI 中,导航到 Content > Products,再点 Red Hat Enterprise Linux Server
  6. 点 Red Hat Enterprise Linux Server 窗口的 Repositories 选项卡,然后点 Red Hat Enterprise Linux 7 Server ISOs x86_64 7.2
  7. 在 Red Hat Enterprise Linux 7 Server ISOs x86_64 7.2 窗口的右上角,点 Select Action 并选择 Sync Now

查看同步状态

  • 在 Satellite Web UI 中,导航到 Content > Sync Status 并展开 Red Hat Enterprise Linux Server

CLI 过程

  1. 找到 Red Hat Enterprise Linux Server for file 软件仓库的产品:

    # hammer repository-set list \
    --product "Red Hat Enterprise Linux Server" \
    --organization "My_Organization" | grep "file"
  2. 为 Red Hat Enterprise Linux 7.2 Server ISO 启用 文件 存储库:

    # hammer repository-set enable \
    --product "Red Hat Enterprise Linux Server" \
    --name "Red Hat Enterprise Linux 7 Server (ISOs)" \
    --releasever 7.2 \
    --basearch x86_64 \
    --organization "My_Organization"
  3. 在产品中找到存储库:

    # hammer repository list \
    --product "Red Hat Enterprise Linux Server" \
    --organization "My_Organization"
  4. 同步产品中的存储库:

    # hammer repository synchronize \
    --name "Red Hat Enterprise Linux 7 Server ISOs x86_64 7.2" \
    --product "Red Hat Enterprise Linux Server" \
    --organization "My_Organization"

12.2. 导入单个 ISO 镜像和文件

使用这个流程手动将 ISO 内容和其他文件导入到卫星服务器。要导入文件,您可以在 Satellite Web UI 中完成以下步骤,或使用hammer CLI。但是,如果您要上传的文件大小大于 15 MB,则必须使用 Hammer CLI 将它上传到存储库。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products,然后在 Products 窗口中点 Create Product
  2. Name 字段中输入名称来标识该产品。此名称会填充 Label 字段。
  3. 可选:在 GPG Key 字段中,为产品输入 GPG 密钥。
  4. 可选:从 Sync Plan 列表中,为该产品选择一个同步计划。
  5. 可选:在 Description 字段中输入产品描述。
  6. Save
  7. 在 Products 窗口中,单击新产品,然后单击 Create Repository
  8. Name 字段中输入存储库的名称。这会自动填充 Label 字段。
  9. Type 列表,选择 文件
  10. Upstream URL 字段中,输入要用作源的 registry 的 URL。在 Upstream UsernameUpstream Password 字段中添加对应的用户名和密码。
  11. Save
  12. 选择新存储库。
  13. 导航到 Upload File,再单击 Browse
  14. 选择 .iso 文件并单击 Upload

CLI 过程

  1. 创建自定义产品:

    # hammer product create \
    --name "My_ISOs" \
    --sync-plan "Example Plan" \
    --description "My_Product" \
    --organization "My_Organization"
  2. 创建存储库:

    # hammer repository create \
    --name "My_ISOs" \
    --content-type "file" \
    --product "My_Product" \
    --organization "My_Organization"
  3. 将 ISO 文件上传到存储库中:

    # hammer repository upload-content \
    --path ~/bootdisk.iso \
    --id repo_ID \
    --organization "My_Organization"

第 13 章 管理 Ansible 内容

您可以将 Ansible 集合从多个源导入到 Satellite 服务器。

如需有关 Satellite 中的 Ansible 集成的更多信息,请参阅在 Red Hat Satellite 中使用 Ansible 集成管理配置

13.1. 同步 Ansible 集合

在 Satellite 上,您可以从 Private Automation Hub、console.redhat.com 和其他 Satellite 实例同步 Ansible Collections。在同步后,Ansible Collections 将会出现在 Satellite web UI 菜单的 Content 下作为一个新的仓库类型。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择所需的产品名称。
  3. Products 窗口中,选择要为其创建存储库的产品名称。
  4. 单击 Repositories 选项卡,然后单击 New Repository
  5. Name 字段中输入存储库的名称。

    Label 字段会根据名称自动填充。

  6. Type 列表中,选择 ansible collection
  7. Upstream URL 字段中,输入上游集合存储库的 URL。

    URL 可以是任何 Ansible Galaxy 端点。例如: https://console.redhat.com/api/automation-hub/

  8. 可选: 在 requirements .yml 字段中,您可以指定您要从端点同步的集合列表及其版本。

    如果没有指定集合列表,则会同步来自端点的所有内容。

    ---
    collections:
    - name: my_namespace.my_collection
      version: 1.2.3

    如需更多信息,请参阅 Galaxy 用户指南中的 从同一 requirements.yml 文件安装角色和集合

  9. 身份验证。

    1. 要从 Private Automation Hub 同步 Satellite,请在 Auth Token 字段中输入您的令牌。

      如需更多信息,请参阅连接到 Hub 中的连接私有 Automation Hub

    2. 要从 console.redhat.com 同步 Satellite,请在 Auth Token 字段中输入您的令牌,然后在 Auth URL 字段中输入您的 SSO URL。

      如需更多信息,请参阅开始使用自动化中心

    3. 要从 Satellite 同步 Satellite,请将这两个身份验证字段留空。
  10. Save
  11. 导航到 Ansible Collections 存储库。
  12. Select Action 菜单中,选择 Sync Now

第 14 章 管理自定义文件类型内容

在 Satellite 中,您可能需要管理和分发 SSH 密钥和源代码文件或者更大的文件,如虚拟机镜像和 ISO 文件。为此,Red Hat Satellite 中的自定义产品包括了用于自定义文件类型的存储库。这提供了一种通用方法,用于在产品中纳入任意文件。

您可以将文件上传到存储库,并从上游卫星服务器同步文件。将文件添加到自定义文件类型存储库时,您可以使用普通的 Satellite 管理功能,如将特定版本添加到内容视图,以提供版本控制并在各种胶囊服务器上提供文件存储库。您必须使用 curl -O 通过 HTTP 或 HTTPS 下载文件。

您只能在 Satellite Server 中创建文件类型存储库,但如何创建存储库源的灵活性。您可以在卫星服务器上的目录中创建独立的存储库源,或者在远程 HTTP 服务器上创建独立存储库源,然后将该目录的内容同步到卫星中。当您有多个要添加到 Satellite 存储库的文件时,此方法很有用。

14.1. 为自定义文件类型存储库创建本地源

您可以使用 Pulp Manifest 在安装 Satellite 的基础系统上,从文件目录中创建自定义文件类型存储库源。然后,您可以将文件同步到存储库,像任何其他内容类型一样管理自定义文件类型内容。

使用这个流程在安装 Satellite 的基础系统的 目录中配置存储库。要在远程服务器上的目录中创建文件类型仓库,请参阅 第 14.2 节 “为自定义文件类型存储库创建远程源”

流程

  1. 确保 Utils 存储库已启用。

    # subscription-manager repos \
    --enable=rhel-8-for-x86_64-appstream-rpms \
    --enable=rhel-8-for-x86_64-baseos-rpms \
    --enable=satellite-utils-6.13-for-rhel-8-x86_64-rpms
  2. 启用 satellite-utils 模块:

    # dnf module enable satellite-utils
  3. 安装 Pulp 清单软件包:

    # satellite-maintain packages install python39-pulp_manifest

    请注意,这个命令会停止 Satellite 服务并重新运行 satellite-installer。另外,为了避免停止该服务导致的停机,您可以使用:

    # satellite-maintain packages unlock
    # dnf install python39-pulp_manifest
    # satellite-maintain packages lock
  4. 创建您要用作文件类型存储库的目录,例如:

    # mkdir -p /var/lib/pulp/local_repos/my_file_repo
  5. 将父文件夹添加到允许的导入路径中:

    # satellite-installer --foreman-proxy-content-pulpcore-additional-import-paths /var/lib/pulp/local_repos
  6. 将文件添加到目录中或创建测试文件:

    # touch /var/lib/pulp/local_repos/my_file_repo/test.txt
  7. 运行 Pulp Manifest 命令来创建清单:

    # pulp-manifest /var/lib/pulp/local_repos/my_file_repo
  8. 验证清单是否已创建:

    # ls /var/lib/pulp/local_repos/my_file_repo
    PULP_MANIFEST test.txt

现在,您可以将本地源导入为自定义文件类型存储库。使用 file:// URL 方案和目录名称来指定 Upstream URL,如 file:///var/lib/pulp/local_repos/my_file_repo。如需更多信息,请参阅 第 14.3 节 “创建自定义文件类型仓库”

如果更新目录的内容,请重新运行 Pulp Manifest,并在 Satellite 中同步存储库。更多信息请参阅 第 5.6 节 “同步软件仓库”

14.2. 为自定义文件类型存储库创建远程源

您可以使用 Pulp Manifest 从卫星服务器外部的文件的目录创建自定义文件类型存储库源。然后,您可以通过 HTTP 或 HTTPS 将文件同步到卫星服务器上的存储库,像任何其他内容类型一样管理自定义文件类型内容。

使用这个流程在远程服务器上的目录中配置存储库。要在安装 Satellite 服务器的基本系统中创建文件类型存储库,请参阅 第 14.1 节 “为自定义文件类型存储库创建本地源”

前提条件

  • 您有一个运行 Red Hat Enterprise Linux 8 的服务器注册到 Satellite 或 Red Hat CDN。
  • 您的服务器有权使用 Red Hat Enterprise Linux 服务器和红帽卫星 Utils 存储库。
  • 已安装 HTTP 服务器。有关配置 Web 服务器的更多信息,请参阅 Red Hat Enterprise Linux 8 中 部署不同类型的服务器

流程

  1. 在服务器上,启用所需的软件仓库:

    # subscription-manager repos \
    --enable=rhel-8-for-x86_64-appstream-rpms \
    --enable=rhel-8-for-x86_64-baseos-rpms \
    --enable=satellite-utils-6.13-for-rhel-8-x86_64-rpms
  2. 启用 satellite-utils 模块:

    # dnf module enable satellite-utils
  3. 安装 Pulp 清单软件包:

    # dnf install python39-pulp_manifest
  4. 在 HTTP 服务器的公共文件夹中,创建一个要用作文件类型存储库的目录:

    # mkdir /var/www/html/pub/my_file_repo
  5. 将文件添加到目录中或创建测试文件:

    # touch /var/www/html/pub/my_file_repo/test.txt
  6. 运行 Pulp Manifest 命令来创建清单:

    # pulp-manifest /var/www/html/pub/my_file_repo
  7. 验证清单是否已创建:

    # ls /var/www/html/pub/my_file_repo
    PULP_MANIFEST test.txt

现在,您可以将远程源导入为自定义文件类型存储库。使用目录的路径指定 Upstream URL,如 http://server.example.com/my_file_repo。更多信息请参阅 第 14.3 节 “创建自定义文件类型仓库”

如果更新目录的内容,请重新运行 Pulp Manifest,并在 Satellite 中同步存储库。更多信息请参阅 第 5.6 节 “同步软件仓库”

14.3. 创建自定义文件类型仓库

创建自定义文件类型存储库的步骤与创建任何自定义内容的步骤相同,但创建存储库时除外,您可以选择 文件类型。您必须创建一个产品,然后添加自定义存储库。

要使用 CLI 而不是 Satellite Web UI,请参阅 CLI 过程

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 选择您要为其创建存储库的产品。
  3. Repositories 选项卡上,单击 New Repository
  4. Name 字段中输入存储库的名称。Satellite 根据名称自动完成 Label 字段。
  5. 可选:在 Description 字段中输入存储库的描述。
  6. Type 列表中,选择 file 作为存储库类型。
  7. 可选:在 Upstream URL 字段中,输入要用作源的上游存储库的 URL。如果没有输入上游 URL,您可以手动上传软件包。如需更多信息,请参阅 第 14.4 节 “将文件上传到自定义文件类型存储库”
  8. 如果要验证上游存储库的 SSL 证书是否由可信 CA 签名,请选择 Verify SSL 复选框。
  9. 可选:在 Upstream Username 字段中,如果需要身份验证,请为上游存储库输入用户名。如果存储库不需要身份验证,请清除此字段。
  10. 可选:在 Upstream Password 字段中,输入上游存储库的对应密码。如果存储库不需要身份验证,请清除此字段。
  11. 可选:在 Upstream Authentication Token 字段中,提供上游存储库用户的令牌进行身份验证。如果存储库不需要身份验证,请将此字段留空。
  12. Mirroring Policy 列表中,选择内容同步卫星服务器所执行的类型。更多信息请参阅 第 5.11 节 “镜像策略概述”
  13. 可选:在 HTTP Proxy Policy 字段中,选择或取消选择使用 HTTP 代理。默认情况下,它使用 Global Default HTTP 代理。
  14. 可选:您可以清除 Unprotected 复选框,要求订阅授权证书才能访问此存储库。默认情况下,存储库通过 HTTP 发布。
  15. 可选: 在 SSL CA Cert 字段中,为存储库选择 SSL CA 证书。
  16. 可选: 在 SSL Client Cert 字段中,为存储库选择 SSL 客户端证书。
  17. 可选: 在 SSL Client Key 字段中,选择存储库的 SSL Client Key。
  18. 单击 Save 以创建存储库。

CLI 过程

  1. 创建自定义产品:

    # hammer product create \
    --description "My_Files" \
    --name "My_File_Product" \
    --organization "My_Organization" \
    --sync-plan "My_Sync_Plan"
    表 14.1. hammer product create 命令的可选参数
    选项Description

    --gpg-key-id gpg_key_id

    GPG 密钥数字标识符

    --sync-plan-id sync_plan_id

    应用计划数字标识符

    --sync-plan sync_plan_name

    Sync plan name to search by

  2. 创建 文件类型 仓库:

    # hammer repository create \
    --content-type "file" \
    --name "My_Files" \
    --organization "My_Organization" \
    --product "My_File_Product"
    表 14.2. hammer 存储库 create 命令的可选参数
    选项Description

    --checksum-type sha_version

    支持仓库校验和,当前 'sha1' 和 'sha256'

    --download-policy policy_name

    yum 存储库下载策略('immediate' 或 'on_demand')。

    --gpg-key-id gpg_key_id

    GPG 密钥数字标识符

    --gpg-key gpg_key_name

    要搜索的键名称

    --mirror-on-sync boolean

    在同步时,源中必须镜像此仓库,并在同步时删除过时的 RPM?设置为 truefalse,是 或 no10。

    --publish-via-http boolean

    这还必须使用 HTTP 发布?设置为 truefalse,是 或 no10。

    --upstream-password repository_password

    上游存储库用户的密码

    --upstream-username repository_username

    upstream repository user,如果需要进行身份验证

    --url source_repo_url

    源存储库的 URL

    --verify-ssl-on-sync boolean

    必须 Katello 验证上游 URL 的 SSL 证书是否由可信 CA 签名?设置为 truefalse,是 或 no10。

14.4. 将文件上传到自定义文件类型存储库

使用这个流程将文件上传到自定义文件类型存储库中。

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 按名称选择自定义产品。
  3. 按名称选择文件类型存储库。
  4. 点击 Browse 搜索并选择您要上传的文件。
  5. 单击 Upload,将所选文件上传到卫星服务器。
  6. 访问发布存储库以查看文件的 URL。

CLI 过程

# hammer repository upload-content \
--id repo_ID \
--organization "My_Organization" \
--path example_file

--path 选项可以指示文件、文件目录或 glob 表达式。glob 必须使用单引号或双引号进行转义。

14.5. 从自定义文件类型存储库将文件下载到主机

您可以使用 curl -O 通过 HTTPS 下载文件到客户端,如果选择了 Unprotected 选项用于存储库,您可以选择通过 HTTP 进行文件。

前提条件

流程

  1. 在 Satellite Web UI 中,导航到 Content > Products
  2. 按名称选择自定义产品。
  3. 按名称选择文件类型存储库。
  4. 确保选中 Unprotected 复选框,以访问通过 HTTP 发布的存储库。
  5. 复制 Published At URL。
  6. 在客户端上,从 Satellite 服务器下载该文件:

    • 对于 HTTPS:

      # curl \
      --cacert ./_katello-server-ca.crt \
      --cert ./_My_Organization_key-cert.pem \
      --remote-name \
      https://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_Product_Label/My_Repository_Label/My_File
    • 对于 HTTP:

      # curl \
      --remote-name \
      http://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_Product_Label/My_Repository_Label/My_File

CLI 过程

  1. 列出文件类型存储库。

    # hammer repository list --content-type file
    ---|------------|-------------------|--------------|----
    ID | NAME       | PRODUCT           | CONTENT TYPE | URL
    ---|------------|-------------------|--------------|----
    7  | My_Files   | My_File_Product   | file         |
    ---|------------|-------------------|--------------|----
  2. 显示存储库信息。

    # hammer repository info \
    --name "My_Files" \
    --organization-id My_Organization_ID \
    --product "My_File_Product"

    如果启用了 未受保护,输出类似如下:

    Publish Via HTTP: yes
    Published At:       https://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_File_Product_Label/My_Files_Label/

    如果没有启用 未受保护,输出类似如下:

    Publish Via HTTP: no
    Published At:       https://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_File_Product_Label/My_Files_Label/
  3. 在客户端上,从 Satellite 服务器下载该文件:

    • 对于 HTTPS:

      # curl \
      --cacert ./_katello-server-ca.crt \
      --cert ./_My_Organization_key-cert.pem \
      --remote-name \
      https://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_Product_Label/My_Repository_Label/My_File
    • 对于 HTTP:

      # curl \
      --remote-name \
      http://satellite.example.com/pulp/content/My_Organization_Label/Library/custom/My_Product_Label/My_Repository_Label/My_File

附录 A. 将 NFS 共享用于内容存储

您的环境需要足够的硬盘空间才能实现内容存储。在某些情况下,使用 NFS 共享来存储此内容非常有用。本附录演示了如何在卫星服务器的内容管理组件中挂载 NFS 共享。

重要

/var/lib/pulp 文件系统使用高带宽、低延迟存储。Red Hat Satellite 有许多 I/O 密集型操作;因此,高延迟、低带宽存储可能会出现性能下降的问题。

流程

  1. 创建 NFS 共享。本例使用 nfs.example.com:/Satellite/pulp 的共享。确保此共享为卫星服务器及其 apache 用户提供适当的权限。
  2. 在 Satellite 服务器中停止 Satellite 服务:

    # satellite-maintain service stop
  3. 确保 Satellite 服务器安装了 nfs-utils 软件包:

    # satellite-maintain packages install nfs-utils
  4. 您需要将 /var/lib/pulp 的现有内容复制到 NFS 共享。首先,将 NFS 共享挂载到临时位置:

    # mkdir /mnt/temp
    # mount -o rw nfs.example.com:/Satellite/pulp /mnt/temp

    /var/lib/pulp 的现有内容复制到临时位置:

    # cp -r /var/lib/pulp/* /mnt/temp/.
  5. 设置共享上所有文件的权限,以使用 pulp 用户。
  6. 卸载临时存储位置:

    # umount /mnt/temp
  7. 删除 /var/lib/pulp 的现有内容:

    # rm -rf /var/lib/pulp/*
  8. 编辑 /etc/fstab 文件并添加以下行:

    nfs.example.com:/Satellite/pulp    /var/lib/pulp   nfs    rw,hard,intr,context="system_u:object_r:pulpcore_var_lib_t:s0"

    这使得挂载在系统重启后仍然有效。确保包含 SELinux 上下文。

  9. 启用挂载:

    # mount -a
  10. 确认 NFS 共享挂载到 var/lib/pulp

    # df
    Filesystem                         1K-blocks     Used Available Use% Mounted on
    ...
    nfs.example.com:/Satellite/pulp 309506048 58632800 235128224  20% /var/lib/pulp
    ...

    另外,确认 var/lib/pulp 的挂载中是否存在现有内容:

    # ls /var/lib/pulp
  11. 在 Satellite 服务器中启动 Satellite 服务:

    # satellite-maintain service start

Satellite 服务器现在使用 NFS 共享来存储内容。运行内容同步,以确保 NFS 共享按预期工作。更多信息请参阅 第 5.6 节 “同步软件仓库”

附录 B. 导入 Kickstart 存储库

Kickstart 软件仓库不是由内容 ISO 镜像提供的。要在断开连接的 Satellite 中使用 Kickstart 软件仓库,您必须为您要使用的 Red Hat Enterprise Linux 版本下载二进制 DVD ISO 文件,并将 Kickstart 文件复制到 Satellite 中。

B.1. 为 Red Hat Enterprise Linux 9 导入 Kickstart 存储库

使用这个流程为 Red Hat Enterprise Linux 9 导入 Kickstart 软件仓库。

流程

  1. 访问位于 access.redhat.com/downloads 的红帽客户门户并登录。
  2. 点击 Red Hat Enterprise Linux
  3. 从列表中选择一个产品变体和一个产品版本。例如,产品变体 Red Hat Enterprise Linux for x86_64 和产品版本 9.0
  4. 找到完整的安装镜像,例如 Red Hat Enterprise Linux 9.0 Binary DVD,然后点 Download Now。请注意,您无法使用最小 ISO 置备主机。
  5. 下载完成后,将 ISO 镜像复制到卫星服务器。
  6. 在服务器上,创建一个挂载点,并在该位置临时挂载 ISO 镜像:

    # mkdir /mnt/iso
    # mount -o loop rhel-binary-dvd.iso /mnt/iso

    rhel-binary-dvd.iso 替换为您的 ISO 镜像的名称。

  7. 为 Red Hat Enterprise Linux 9 AppStream 和 BaseOS Kickstart 软件仓库创建目录:

    # mkdir --parents /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/kickstart
    # mkdir --parents /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/kickstart
  8. 从 ISO 镜像复制 kickstart 文件:

    # cp -a /mnt/iso/AppStream/* /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/kickstart
    # cp -a /mnt/iso/BaseOS/* /mnt/iso/images/ /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/kickstart

    请注意,对于 BaseOS,还必须复制 /mnt/iso/images/ 目录的内容。

  9. 在列出文件中添加以下条目:

    /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/listing 文件,使用新行附加 kickstart

    /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/listing 文件,使用新行附加 kickstart

    /var/www/html/pub/satellite-import/content/dist/rhel8/listing 文件中,使用新行附加版本号。例如,对于 Red Hat Enterprise Linux 9.0 二进制 ISO,请附加 9.0

  10. 从 ISO 镜像复制 .treeinfo 文件:

    # cp /mnt/iso/.treeinfo /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/kickstart/treeinfo
    # cp /mnt/iso/.treeinfo /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/kickstart/treeinfo
  11. 打开 /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/kickstart/treeinfo 文件进行编辑。
  12. [general] 部分中,进行以下更改:

    • packagedir = AppStream/Packages 改为 packagedir = Packages
    • 将存储库 = AppStream 更改为 repository= .
    • 变体 = AppStream 改为 变体 = BaseOS
    • 变体 = AppStream,BaseOS 改为 变体 = BaseOS
  13. [tree] 部分中,将 变体 = AppStream,BaseOS 改为 变体 = BaseOS
  14. [variant-BaseOS] 部分中,进行以下更改:

    • 软件包 = BaseOS/Packages 更改为 软件包 = package
    • 将存储库 = BaseOS 更改为 repository= .
  15. 删除 [media][variant-AppStream] 部分。
  16. 保存并关闭该文件。
  17. 验证 /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/baseos/kickstart/treeinfo 文件是否采用以下格式:

    [checksums]
    images/efiboot.img = sha256:c01c18acc6778d6e66c8d0872bac59bfd7219ccf3cfa70a5c605c0fb37f33a83
    images/install.img = sha256:ddd08e5a5d92edee150f91ff4f12f39253eae72ff496465cf1b2766fe4a4df49
    images/pxeboot/initrd.img = sha256:a09a8ec89d485d71ed1bdad83584d6d816e67448221172d9aad97886cd70adca
    images/pxeboot/vmlinuz = sha256:6e523d7c3266e26c695923ab12b2873b16b0c61fb2e48ade608ad8998821584b
    
    [general]
    ; WARNING.0 = This section provides compatibility with pre-productmd treeinfos.
    ; WARNING.1 = Read productmd documentation for details about new format.
    arch = x86_64
    family = Red Hat Enterprise Linux
    name = Red Hat Enterprise Linux 9.0.0
    packagedir = Packages
    platforms = x86_64,xen
    repository = .
    timestamp = 1571146127
    variant = BaseOS
    variants = BaseOS
    version = 9.0.0
    
    [header]
    type = productmd.treeinfo
    version = 1.2
    
    [images-x86_64]
    efiboot.img = images/efiboot.img
    initrd = images/pxeboot/initrd.img
    kernel = images/pxeboot/vmlinuz
    
    [images-xen]
    initrd = images/pxeboot/initrd.img
    kernel = images/pxeboot/vmlinuz
    
    [release]
    name = Red Hat Enterprise Linux
    short = RHEL
    version = 9.0.0
    
    [stage2]
    mainimage = images/install.img
    
    [tree]
    arch = x86_64
    build_timestamp = 1571146127
    platforms = x86_64,xen
    variants = BaseOS
    
    [variant-BaseOS]
    id = BaseOS
    name = BaseOS
    packages = Packages
    repository = .
    type = variant
    uid = BaseOS
  18. 打开 /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/kickstart/treeinfo 文件进行编辑。
  19. [general] 部分中,进行以下更改:

    • packagedir = AppStream/Packages 改为 packagedir = Packages
    • 将存储库 = AppStream 更改为 repository= .
    • 变体 = AppStream,BaseOS 改为 变体 = AppStream
  20. [tree] 部分中,将 变体 = AppStream,BaseOS 改为 变体 = AppStream
  21. [variant-AppStream] 部分中,进行以下更改:

    • 软件包 = AppStream/Packages 改为 package = package
    • 将存储库 = AppStream 更改为 repository= .
  22. 删除文件中的以下部分:[checksums] , [images-x86_64] , [images-xen], [media], [stage2], [variant-BaseOS].
  23. 保存并关闭该文件。
  24. 验证 /var/www/html/pub/satellite-import/content/dist/rhel9/9.0/x86_64/appstream/kickstart/treeinfo 文件是否采用以下格式:

    [general]
    ; WARNING.0 = This section provides compatibility with pre-productmd treeinfos.
    ; WARNING.1 = Read productmd documentation for details about new format.
    arch = x86_64
    family = Red Hat Enterprise Linux
    name = Red Hat Enterprise Linux 9.0.0
    packagedir = Packages
    platforms = x86_64,xen
    repository = .
    timestamp = 1571146127
    variant = AppStream
    variants = AppStream
    version = 9.0.0
    
    [header]
    type = productmd.treeinfo
    version = 1.2
    
    [release]
    name = Red Hat Enterprise Linux
    short = RHEL
    version = 9.0.0
    
    [tree]
    arch = x86_64
    build_timestamp = 1571146127
    platforms = x86_64,xen
    variants = AppStream
    
    [variant-AppStream]
    id = AppStream
    name = AppStream
    packages = Packages
    repository = .
    type = variant
    uid = AppStream
  25. 如果您不打算使用挂载的二进制 DVD ISO 镜像,卸载并删除该目录:

    # umount /mnt/iso
    # rmdir /mnt/iso
  26. 在 Satellite Web UI 中,启用 Kickstart 存储库。

B.2. 为 Red Hat Enterprise Linux 8 导入 Kickstart 存储库

使用这个流程为 Red Hat Enterprise Linux 8 导入 Kickstart 软件仓库。

流程

  1. 访问位于 access.redhat.com/downloads 的红帽客户门户并登录。
  2. 点击 Red Hat Enterprise Linux
  3. 从列表中选择一个产品变体和一个产品版本。例如,产品变体 Red Hat Enterprise Linux for x86_64 和产品版本 8.1
  4. 找到完整安装镜像,例如 Red Hat Enterprise Linux 8.1 Binary DVD,然后点 Download Now
  5. 下载完成后,将 ISO 镜像复制到卫星服务器。
  6. 在服务器上,创建一个挂载点,并在该位置临时挂载 ISO 镜像:

    # mkdir /mnt/iso
    # mount -o loop rhel-binary-dvd.iso /mnt/iso

    rhel-binary-dvd.iso 替换为您的 ISO 镜像的名称。

  7. Create directories for Red Hat Enterprise Linux 8 AppStream and BaseOS Kickstart repositories:

    # mkdir --parents /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/kickstart
    # mkdir --parents /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/kickstart
  8. 从 ISO 镜像复制 kickstart 文件:

    # cp -a /mnt/iso/AppStream/* /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/kickstart
    # cp -a /mnt/iso/BaseOS/* /mnt/iso/images/ /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/kickstart

    请注意,对于 BaseOS,还必须复制 /mnt/iso/images/ 目录的内容。

  9. 在列出文件中添加以下条目:

    /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/listing 文件中,使用新行附加 kickstart

    /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/listing 文件,使用新行附加 kickstart

    /var/www/html/pub/satellite-import/content/dist/rhel8/listing 文件中,使用新行附加版本号。例如,对于 Red Hat Enterprise Linux 8.1 二进制 ISO,请附加 8.1

  10. 从 ISO 镜像复制 .treeinfo 文件:

    # cp /mnt/iso/.treeinfo /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/kickstart/treeinfo
    # cp /mnt/iso/.treeinfo /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/kickstart/treeinfo
  11. 打开 /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/kickstart/treeinfo 文件进行编辑。
  12. [general] 部分中,进行以下更改:

    • packagedir = AppStream/Packages 改为 packagedir = Packages
    • 将存储库 = AppStream 更改为 repository= .
    • 变体 = AppStream 改为 变体 = BaseOS
    • 变体 = AppStream,BaseOS 改为 变体 = BaseOS
  13. [tree] 部分中,将 变体 = AppStream,BaseOS 改为 变体 = BaseOS
  14. [variant-BaseOS] 部分中,进行以下更改:

    • 软件包 = BaseOS/Packages 更改为 软件包 = package
    • 将存储库 = BaseOS 更改为 repository= .
  15. 删除 [media][variant-AppStream] 部分。
  16. 保存并关闭该文件。
  17. 验证 /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/baseos/kickstart/treeinfo 文件是否采用以下格式:

    [checksums]
    images/efiboot.img = sha256:c01c18acc6778d6e66c8d0872bac59bfd7219ccf3cfa70a5c605c0fb37f33a83
    images/install.img = sha256:ddd08e5a5d92edee150f91ff4f12f39253eae72ff496465cf1b2766fe4a4df49
    images/pxeboot/initrd.img = sha256:a09a8ec89d485d71ed1bdad83584d6d816e67448221172d9aad97886cd70adca
    images/pxeboot/vmlinuz = sha256:6e523d7c3266e26c695923ab12b2873b16b0c61fb2e48ade608ad8998821584b
    
    [general]
    ; WARNING.0 = This section provides compatibility with pre-productmd treeinfos.
    ; WARNING.1 = Read productmd documentation for details about new format.
    arch = x86_64
    family = Red Hat Enterprise Linux
    name = Red Hat Enterprise Linux 8.1.0
    packagedir = Packages
    platforms = x86_64,xen
    repository = .
    timestamp = 1571146127
    variant = BaseOS
    variants = BaseOS
    version = 8.1.0
    
    [header]
    type = productmd.treeinfo
    version = 1.2
    
    [images-x86_64]
    efiboot.img = images/efiboot.img
    initrd = images/pxeboot/initrd.img
    kernel = images/pxeboot/vmlinuz
    
    [images-xen]
    initrd = images/pxeboot/initrd.img
    kernel = images/pxeboot/vmlinuz
    
    [release]
    name = Red Hat Enterprise Linux
    short = RHEL
    version = 8.1.0
    
    [stage2]
    mainimage = images/install.img
    
    [tree]
    arch = x86_64
    build_timestamp = 1571146127
    platforms = x86_64,xen
    variants = BaseOS
    
    [variant-BaseOS]
    id = BaseOS
    name = BaseOS
    packages = Packages
    repository = .
    type = variant
    uid = BaseOS
  18. 打开 /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/kickstart/treeinfo 文件进行编辑。
  19. [general] 部分中,进行以下更改:

    • packagedir = AppStream/Packages 改为 packagedir = Packages
    • 将存储库 = AppStream 更改为 repository= .
    • 变体 = AppStream,BaseOS 改为 变体 = AppStream
  20. [tree] 部分中,将 变体 = AppStream,BaseOS 改为 变体 = AppStream
  21. [variant-AppStream] 部分中,进行以下更改:

    • 软件包 = AppStream/Packages 改为 package = package
    • 将存储库 = AppStream 更改为 repository= .
  22. 删除文件中的以下部分:[checksums] , [images-x86_64] , [images-xen], [media], [stage2], [variant-BaseOS].
  23. 保存并关闭该文件。
  24. 验证 /var/www/html/pub/satellite-import/content/dist/rhel8/8.1/x86_64/appstream/kickstart/treeinfo 文件是否采用以下格式:

    [general]
    ; WARNING.0 = This section provides compatibility with pre-productmd treeinfos.
    ; WARNING.1 = Read productmd documentation for details about new format.
    arch = x86_64
    family = Red Hat Enterprise Linux
    name = Red Hat Enterprise Linux 8.1.0
    packagedir = Packages
    platforms = x86_64,xen
    repository = .
    timestamp = 1571146127
    variant = AppStream
    variants = AppStream
    version = 8.1.0
    
    [header]
    type = productmd.treeinfo
    version = 1.2
    
    [release]
    name = Red Hat Enterprise Linux
    short = RHEL
    version = 8.1.0
    
    [tree]
    arch = x86_64
    build_timestamp = 1571146127
    platforms = x86_64,xen
    variants = AppStream
    
    [variant-AppStream]
    id = AppStream
    name = AppStream
    packages = Packages
    repository = .
    type = variant
    uid = AppStream
  25. 如果您不打算使用挂载的二进制 DVD ISO 镜像,卸载并删除该目录:

    # umount /mnt/iso
    # rmdir /mnt/iso
  26. 在 Satellite Web UI 中,启用 Kickstart 存储库。

B.3. 为 Red Hat Enterprise Linux 7 导入 Kickstart 存储库

使用这个流程为 Red Hat Enterprise Linux 7 导入 Kickstart 软件仓库。

流程

  1. 访问位于 access.redhat.com/downloads 的红帽客户门户并登录。
  2. 点击 Red Hat Enterprise Linux
  3. Switch to version 7,然后在 产品变体 列表上方的下方
  4. 从列表中选择一个产品变体和一个产品版本。例如,产品变体 Red Hat Enterprise Linux for x86_64 和产品版本 7.9
  5. 找到完整的安装镜像,如 Red Hat Enterprise Linux 7.9 Binary DVD,然后点 Download Now
  6. 下载完成后,将 ISO 镜像复制到卫星服务器。
  7. 在服务器上,创建一个挂载点,并在该位置临时挂载 ISO 镜像:

    # mkdir /mnt/iso
    # mount -o loop rhel-binary-dvd.iso /mnt/iso

    rhel-binary-dvd.iso 替换为您的 ISO 镜像的名称。

  8. 创建 Kickstart 目录:

    # mkdir --parents /var/www/html/pub/satellite-import/content/dist/rhel/server/7/7.9/x86_64/kickstart/
  9. 从 ISO 镜像复制 kickstart 文件:

    # cp -a /mnt/iso/* /var/www/html/pub/satellite-import/content/dist/rhel/server/7/7.9/x86_64/kickstart/
  10. 在列出文件中添加以下条目:

    /var/www/html/pub/satellite-import/content/dist/rhel/server/7/listing 文件,使用新行附加版本号。例如,对于 Red Hat Enterprise Linux 7.9 ISO,请附加 7.9

    /var/www/html/pub/satellite-import/content/dist/rhel/server/7/7.9/listing 文件中,使用新行附加架构。例如,x86_64

    /var/www/html/pub/satellite-import/content/dist/rhel/server/7/7.9/x86_64/listing 文件,使用新行附加 kickstart

  11. 从 ISO 镜像复制 .treeinfo 文件:

    # cp /mnt/iso/.treeinfo /var/www/html/pub/satellite-import/content/dist/rhel/server/7/7.9/x86_64/kickstart/treeinfo
  12. 如果您不打算使用挂载的二进制 DVD ISO 镜像,卸载并删除该目录:

    # umount /mnt/iso
    # rmdir /mnt/iso
  13. 在 Satellite Web UI 中,启用 Kickstart 存储库。

法律通告

Copyright © 2024 Red Hat, Inc.
The text of and illustrations in this document are licensed by Red Hat under a Creative Commons Attribution–Share Alike 3.0 Unported license ("CC-BY-SA"). An explanation of CC-BY-SA is available at http://creativecommons.org/licenses/by-sa/3.0/. In accordance with CC-BY-SA, if you distribute this document or an adaptation of it, you must provide the URL for the original version.
Red Hat, as the licensor of this document, waives the right to enforce, and agrees not to assert, Section 4d of CC-BY-SA to the fullest extent permitted by applicable law.
Red Hat, Red Hat Enterprise Linux, the Shadowman logo, the Red Hat logo, JBoss, OpenShift, Fedora, the Infinity logo, and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux® is the registered trademark of Linus Torvalds in the United States and other countries.
Java® is a registered trademark of Oracle and/or its affiliates.
XFS® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States and/or other countries.
MySQL® is a registered trademark of MySQL AB in the United States, the European Union and other countries.
Node.js® is an official trademark of Joyent. Red Hat is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.
The OpenStack® Word Mark and OpenStack logo are either registered trademarks/service marks or trademarks/service marks of the OpenStack Foundation, in the United States and other countries and are used with the OpenStack Foundation's permission. We are not affiliated with, endorsed or sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.