赛尔校园公共服务平台 Logo
平台使用
阿里云
百度云
移动云
智算服务
教育生态
登录 →
赛尔校园公共服务平台 Logo
平台使用 阿里云 百度云 移动云 智算服务 教育生态
登录
  1. 首页
  2. 阿里云
  3. Serverless应用引擎(新版)
  4. 操作指南
  5. 命名空间
  6. 管理和使用保密字典(K8s Secret)

管理和使用保密字典(K8s Secret)

  • 命名空间
  • 发布于 2025-04-17
  • 0 次阅读
文档编辑
文档编辑

保密字典是Kubernetes中一种用于保管敏感信息如密钥和证书的资源。为了防止这些信息被泄露到镜像或部署配置中,推荐您使用保密字典。保密字典是在命名空间级别进行管理的。一旦设置了保密字典,您可以在创建应用或部署版本时,把敏感配置直接注入容器,而无需再次向镜像内部添加。当Secret的内容有所更改,仅需要重新部署相关的应用,即可更新配置并使其生效。

背景信息

在Serverless 应用引擎 SAE(Serverless App Engine)环境中,ConfigMap和Secret是两种用来存储配置信息的资源,它们都允许将配置与容器镜像分离,便于应用配置的管理。不过,它们之间的适用场景有所不同。

  • ConfigMap通常被用于存储常规配置项,如配置文件内容、命令行参数和其他非机密数据。它们能够以文件挂载、环境变量或命令行参数的方式注入到Pod内,使您能够轻松地更新应用设置而无需重建容器镜像。

  • Secret主要用于保存敏感数据,例如密码、证书和SSH密钥等。与ConfigMap类似,Secret可以作为文件挂载或者以环境变量的形式提供给Pod的容器。为了降低泄露的危险,Kubernetes对Secret中的数据进行了加密,并在内存中安全地处理。

前提条件

已创建命名空间。

注意事项

  • SAE的镜像部署,默认为免密拉取镜像。如果部署时使用保密字典,则原有免密拉取镜像不再生效。如果需要免密拉取镜像,请先重新部署,并取消选择保密字典。

  • 修改后的保密字典新版本仅对应用新实例(如手动新扩容或自动弹性的新实例)生效,对存量实例不生效。为保证应用所有实例保密字典版本的最终一致性,请您在修改保密字典后手动重启或部署应用。

  • 如果您需要删除保密字典,且已有应用在使用该保密字典,请先在关联的应用中解除该保密字典,然后再进行删除该保密字典,以免影响这些应用的正常运行。

  • 如果您的配置项信息无需加密,则无需使用保密字典功能。您可以使用SAE的配置项功能来管理配置信息。具体操作,请参见管理和使用配置项(K8s ConfigMap)。

创建保密字典

  1. 登录SAE控制台。

  2. 在左侧导航栏,单击命名空间,在顶部菜单栏选择目标地域,然后单击目标命名空间名称。

  3. 在左侧导航栏,单击保密字典,在保密字典页面,单击创建。

  4. 在弹出的创建面板,根据需求选择不同的保密字典类型并根据下表说明完成参数配置,然后单击确定。

    说明

    在创建保密字典时,您可以根据需要存放的信息选择不同的类型:

    • Opaque类型:Opaque是默认的Secret类型,适用于存储各类没有特定格式的敏感信息,如密码或API密钥。当您需要存储一些自定义格式的敏感信息时,Opaque类型提供了灵活性,让您可以以键值对的形式自由地保存所需的数据。

    • TLS证书类型:这种类型专门用于存储TLS证书相关的数据,当您的服务需要启用HTTPS访问时,可以使用这种类型的Secret来保存和管理TLS证书,以确保在SAE环境中的Pod中使用,确保数据传输的安全性。

    • 私有镜像仓库登录密钥类型:这种类型适用于存储访问私有容器镜像仓库的凭证,使得Kubernetes在拉取私有镜像时能够进行身份验证。如果您的应用使用的容器镜像存储在私有仓库中,您需要提供凭证才能访问这些镜像。在这种情况下,该类型的Secret用于存储仓库用户名和密码或访问令牌,确保SAE在部署应用时能够拉取到私有镜像。

    Opaque类型

    配置项

    说明

    名称

    自定义保密字典名称。

    类型

    选择Opaque类型。

    键值对

    • 对数据值进行Base64编码:默认选中,SAE会对明文数据进行Base64编码。

    • 键值对:敏感信息的Key和Value。

    说明

    单击+添加,可以定义多个键值对。

    TLS证书类型

    配置项

    说明

    名称

    自定义保密字典名称。

    类型

    选择TLS证书类型。

    Cert

    TLS证书的公钥。

    Key

    TLS证书的私钥。

    私有镜像仓库登录密钥类型

    配置项

    说明

    名称

    自定义保密字典名称。

    类型

    选择私有镜像仓库登录密钥类型。

    镜像仓库地址

    镜像仓库地址:请填写敏感信息所在的镜像仓库对应的VPC内网域名,例如:******-vpc.cn-beijing.aliyuncs.com。关于如何获取,请参见镜像仓库。

    用户名

    镜像仓库的用户名。

    密码

    镜像仓库的密码。

    创建的保密字典将显示在保密字典页面,您可以在保密字典列表的操作列进行编辑、复制和删除操作。

通过保密字典拉取镜像

如果想要通过保密字典拉取镜像,您需要先创建私有镜像仓库登录密钥类型的保密字典。本文仅介绍配置保密字典的关键信息。关于配置项的更多信息,请参见使用WAR包部署Java应用和任务模板管理。

说明

本文仅介绍关键步骤。

在创建应用过程中配置保密字典

该功能可以在创建应用时设置,也可以在更新应用时设置。

  1. 登录SAE控制台,在左侧导航栏选择应用管理 > 应用列表,然后选择目标地域和目标命名空间,最后单击创建应用。

    xxQdc1LHvq

  2. 选择应用部署方式为选择镜像部署,然后单击设置镜像。

  3. 在弹出的设置镜像面板,根据以下说明完成参数配置,然后单击确定。

    1. 选择技术栈语言,Java和PHP语言可以选择环境版本。如Java语言的环境选择为Open JDK 8。

    2. 单击其他阿里云账号私有镜像。

    3. 在其他阿里云账号私有镜像页签,选择镜像服务版本为镜像服务个人版或镜像服务企业版。

      • 如果您选择的是镜像服务个人版,将镜像类型选择为静态用户名和密码,然后填写存储镜像仓库用户名和密码的保密字典和完整镜像仓库地址。

      • 如果您选择的是镜像服务企业版,将镜像类型选择为静态用户名和密码,然后填写企业版实例ID、存储镜像仓库用户名和密码的保密字典和完整镜像仓库地址。

  4. 按照页面提示完成其他参数设置,然后单击下一步:高级设置。

  5. 在高级设置页面,完成高级参数配置。具体操作,请参见高级配置。

  6. 单击创建应用。

在创建任务模板过程中配置保密字典

  1. 登录SAE控制台。

  2. 在左侧导航栏,单击任务模板列表,然后在顶部菜单栏选择目标地域。

  3. 在任务模板列表页面,单击创建任务模板。

  4. 在任务基本信息页面,按照页面说明完成参数配置,然后单击下一步:部署配置。

  5. 在部署配置页面,按照以下步骤完成参数配置。

    1. 选择技术栈语言,Java和PHP语言可以选择环境版本。如Java语言的环境选择为Open JDK 8。

    2. 单击其他阿里云账号私有镜像。

    3. 在其他阿里云账号私有镜像页签,选择镜像服务版本为镜像服务个人版或镜像服务企业版。

      • 如果您选择的是镜像服务个人版,将镜像类型选择为静态用户名和密码,然后填写存储镜像仓库用户名和密码的保密字典和完整镜像仓库地址。

      • 如果您选择的是镜像服务企业版,将镜像类型选择为静态用户名和密码,然后填写企业版实例ID、存储镜像仓库用户名和密码的保密字典和完整镜像仓库地址。

  6. 根据页面提示完成其他参数配置,然后单击下一步:任务设置。

  7. 根据页面提示完成参数设置,然后单击下一步:确认规格。

  8. 在确认规格页面,仔细确认配置信息,然后单击确认创建。

    创建完成后,在任务模板列表页面,查看已创建的任务信息。

相关文章

管理命名空间 2025-04-17 11:00

命名空间为您的应用提供逻辑隔离的运行环境,方便应用的服务调用,以及分布式配置推送。如果您有开发环境、测试环境和生产环境等场景,建议使用命名空间,将不同场景下的应用进行逻辑隔离,便于管理应用及一键启停应用,提高应用安全性。本文介绍如何在SAE控制台管理命名空间,包括创建、编辑、删除等操作。 背景信息

管理和使用配置项(K8s ConfigMap) 2025-04-17 11:00

命名空间中的配置项用于存储应用所需的配置信息,它可以作为容器运行环境中的环境变量,便于应用部署后灵活变更容器配置,也可以通过命令行参数或挂载配置文件的方式向容器中注入配置信息。本文介绍如何在SAE控制台创建和使用命名空间的配置项。 背景信息

管理和使用保密字典(K8s Secret) 2025-04-17 11:00

保密字典是Kubernetes中一种用于保管敏感信息如密钥和证书的资源。为了防止这些信息被泄露到镜像或部署配置中,推荐您使用保密字典。保密字典是在命名空间级别进行管理的。一旦设置了保密字典,您可以在创建应用或部署版本时,把敏感配置直接注入容器,而无需再次向镜像内部添加。当Secret的内容有所更改,

创建定时启停规则 2025-04-17 11:00

为了节省成本,您可以为应用设置定时启停规则。处于停止状态的应用不产生计算资源的费用。 如果需要手动批量启停应用,请参考对应用进行批量操作。 如果需要定时批量启停应用,请参考本文。

对应用进行批量操作 2025-04-17 11:00

在同一命名空间下,Serverless 应用引擎支持对多个应用进行批量操作,包括批量启动、批量停止、批量设置标签以及批量开启或关闭ARMS高级监控功能。此外,SAE还支持一键导出指定地域下所有命名空间中

分布式配置管理 2025-04-17 11:00

Serverless 应用引擎 SAE(Serverless App Engine)为您提供了一个易于管理、支持动态更新、环境分离、版本控制、加密安全和细粒度权限控制的高可用配置管理方案,您可以在SAE中对应用配置进行集中管理。

目录
Copyright © 2025 your company All Rights Reserved. Powered by 赛尔网络.
京ICP备14022346号-15
gongan beian 京公网安备11010802041014号