首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

采用基础设施即代码的演练

也许我们正在创建一个容器化应用程序,一个机器学习流水线,或者启动一个 Kubernetes 集群。在所有这些情况下,首先需要了解组成我们架构的云资源。...我们的某些配置可能涉及使用敏感信息,例如 Stripe 访问密钥数据库密码或其他类型的秘密令牌。...这就是 Pulumi 密钥系统的用武之地,它提供了内置的加密和安全存储,用于存储这些设置。...例如,可以有一个基本的网络和安全层、一个数据堆栈和一个 Kubernetes 集群,它们从较低层次消耗信息,但是可以单独进行配置,而上面的应用程序则依赖于上述所有元素的不同组合。...现在让我们为我们的应用程序创建一个数据库,并将其扩展到三个副本,只是为了好玩。我们首先进行代码更改: 然后再次运行 pulumi up。

10110

GitOps 和 Kubernetes 中的 secret 管理

如果加密密钥被泄露,则可能很难追踪使用泄露密钥加密的所有数据并将其撤消,因为这些数据可能会散布在大量存储库中。...尽管 Secrets Store CSI 驱动程序确实提供了将内容同步到 Kubernetes 中的 Secret 资源的可选功能,但由于作为 CSI 实现的性质,驱动程序及其创建密钥最终将绑定到工作负载...此外,另一个限制因素是,如果删除了工作负载,则可选创建Secret 也将被删除。 目前,对轮转密钥的支持有限,该功能仍处于 alpha 状态,并非所有提供商都支持。...避免创建 Kubernetes Secret 可以减轻一些保护 etcd 的需求,但是在 Kubernetes 中几乎不可避免,因为太多的核心和附加功能依赖于 Kubernetes Secret。...例如,密钥管理系统可以与数据库协调,动态创建范围更小、寿命较短的数据库凭证。

1.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

Pulumi用户现可使用GitOps方法管理云端基础设施

这次Pulumi推出了一个新的集群Pulumi Kubernetes Operator,能让用户以GitOps的方式,管理云端和Kubernetes集群上的基础设施,该Kubernetes Operator...Pulumi还推出了称为crd2pulumi的工具,可以为任何Kubernetes CRD(Custom Resource Definition)创建强类型的API,让用户能够简单地使用云端原生社群的各种...另外,Pulumi还推出可以将Kubernetes YAML清单转换为Python、TypeScript、Go或者.NET程序语言的工具kube2pulumi,由于Pulumi支援完整的Kubernetes...API,因此kube2pulumi产生的程序码,就包含了Kubernetes所有功能。...3和配置管理工具Kustomize,两者可以作为Pulumi程序的一部分,使用核心Pulumi Kubernetes函数库。

1.2K10

基础设施设施即代码(IaC)平台 Pulumi | 混合云管理利器

Pulumi 的结构和主要组件 程序结构如上图,Pulumi 代码是保存在一个项目中,该项目是一个包含程序源码和运行程序元数据的目录。...程序编写完成后,只需在项目目录中运行 Pulumi CLI 命令 pulumi up,就可以为你的程序创建了一个独立的、可配置的实例,称为堆栈(Stack)。...优势 Pulumi 可以让你使用最喜欢的编程语言在多云(包括 AWS、Azure、谷歌云、Kubernetes、OpenStack等)上配置和管理资源。...它对众多的云基础设施和应用程序非常有效,包括容器、虚拟机、数据库、云服务和 Serverless。 由于这种广泛的支持场景,使得许多工具与 Pulumi 的能力相重叠。...而 Pulumi 的优势在于: 多语言支持支持常用的编程语言来编写配置,学习成本低。 混合云支持维护人员可以使用 Pulumi 来管理和维护多个公有云、OpenStack 和 Kubernetes

2K20

任何编程语言的基础设施即代码

这些应用程序需要直接使用的基础设施,比如它们运行在其中的任何内容(例如虚拟机、容器化服务、无服务器函数、静态网站),以及它们使用的任何其他资源(数据库、发布/订阅主题、队列、AI/ML服务、可观测性指标和仪表板...),但它们也依赖于更原始的基础设施来运行(如Kubernetes集群、安全角色和权限、私有网络、负载均衡器、加密密钥等)。...如果这是您第一次创建某个环境,Pulumi称之为“堆栈(stack)”,那么当然所有声明的基础设施都需要从头创建。...一些基础设施即代码工具仅支持一个云平台,但我们选择的工具 Pulumi 支持多个云平台,包括上述提到的所有云平台,因此可以在所有云平台和服务提供商之间标准化所有这些工作流程。...它甚至可以跟踪云服务之间的依赖关系,例如,在 AWS 中预置一个弹性 Kubernetes 服务集群,在其节点上安装 Datadog 代理,部署一些 Kubernetes 工作负载,并在该应用程序前面放置

9710

7 个值得关注的开源云原生工具

下面列出一些云原生工具,这些工具对于不使用 Kubernetes 或未将其用于所有工作负载的团队非常有用。 1. Nomad 你知道除了 Kubernetes 之外还有容器编排器吗?...如果你需要编排一些容器,而 Kubernetes 似乎有点过头了,你可以试试 Nomad。 2. Pulumi 我在基础设施即代码世界中度过了几年的时间,这个话题仍然让我很感兴趣。...它绝对是用于 Kubernetes 和其他云原生应用程序的最流行的可观察性工具之一。但是如何设置 Prometheus 使其具有高可用性和可扩展性?您如何处理所有数据?...4.etcd 虽然 etcd 以 Kubernetes 集群的数据存储而闻名,但您可以用它做更多事情。...Kuma 是由 Kong 的团队创建的,它与开源 Kong Gateway 集成。Kuma 被捐赠给 CNCF,目前是 CNCF 沙盒项目。

95410

追赶 terraform,让基础设施代码化更加容易,pulumi 都做了些什么?

好久写 devOps 代码,程序君感觉莫名手欠。最近看着一个开源项目 pulumi 比较有意思,这个周末就在自己的 aws 账号里作死尝试了一把,嗯,还挺香。究竟有多香呢,我们来一起探索吧。...巧的是,同年 9 月,kubernetes 第一个 release v0.2 在 github 上发布。...,所以下述的资源都会创建在 aws 的 us-west-2 区域,就是美国西海岸俄勒冈的数据中心。...pulumi 闪亮登场 pulumi 诞生于 2017 年,是微软和亚马逊云服务的老兵 Joe Duffy(CEO) 和 Luke Hoban(CTO)创建的,对标 terraform 的一款软件。...比如上文中创建一个 openresty EC2 实例的代码,用 typescript 可以这么写: import * as pulumi from "@pulumi/pulumi"; import *

2.7K20

加密 K8s Secrets 的几种方案

也可能是任何被授权在 Namespace 中创建 pod 或 Deploy,然后使用该权限检索该 Namespace 中所有 Secrets 的人。...3.开发者创建一个 Secret 资源,然后由 kubeseal CLI 在运行时从控制器中获取密钥,对该资源进行加密或密封。对于网络受限的环境,公钥也可以存储在本地并由 kubeseal 使用。...在集群上,管理员将: 1.部署 ArgoCD2.使用 age 生成密钥3.在 特定(如 GitOps) Namespace 中创建存储公钥和私钥的密钥4.定制 Argo CD 以使用 Kustomize...创建加密 EBS 卷并将其附加到支持的实例类型时,以下类型的数据将被加密:•加密卷内的静态数据•卷和实例之间移动的所有数据•从加密卷创建所有快照•从这些快照创建所有卷2.Azure: 为连接到 Azure...希望将秘密存储在 etcd 中作为 Kubernetes 秘密的客户主要会选择 SSCSI,原因如下 •他们可能有严格的合规性要求,因此有必要仅在中央存储区而非集群中存储和管理机密。

73520

普通Kubernetes Secret足矣

创建威胁模型可以帮助您做出这些决定。让我们为 Kubernetes 密钥创建一个简单的威胁模型,看看会出现什么。 Kubernetes Secret的简单威胁模型 我们在保护什么?...Secret通常用于存储数据库密码和私钥,这意味着它们是一个高价值目标。 安全失败看起来像什么?...如果攻击者能够读取Secret,他们可以使用它执行进一步的攻击,例如窃取数据、修改/删除/勒索数据,或者获得授权执行诸如开采加密货币的 Pod 等操作。...etcd 静态加密涉及使用存储在 etcd 本身相同文件系统上的密钥加密 etcd 中的所有Secret。因此,我们的威胁模型中的四种攻击都没有得到缓解。...使用加密磁盘并将密钥存储在安全的地方会以更简单、更便宜的方式提供相同级别的安全性。 结论 通过创建一个包括你想要缓解的攻击类型的威胁模型,很明显,安全地管理机密信息非常困难。

6710

白话 Kubernetes 基础概念

例如,您可以自动化 Kubernetes 来为您的部署创建新容器,删除现有容器并将它们的所有资源用于新容器。 容器资源配额:Kubernetes 允许您指定每个容器所需 CPU 和内存(RAM)。...Secret Secret 解决了密码、token、密钥等敏感数据的配置问题,而不需要把这些敏感数据暴露到镜像或者Pod Spec中。Secret 可以以Volume或者环境变量的方式使用。...Secret有三种类型: Service Account :用来访问Kubernetes API,由Kubernetes自动创建,并且会自动挂载到Pod的/run/secrets/kubernetes.io.../serviceaccount目录中; Opaque :base64编码格式的Secret,用来存储密码、密钥等; kubernetes.io/dockerconfigjson :用来存储私有docker...PV 和 PVC 用于数据持续存储,Pod中,容器销毁,所有数据都会被销毁,如果需要保留数据,这里就需要用到 PV存储卷,PVC存储卷申明。 PVC 常用于 Deployment 做数据持久存储。

84821

【云原生 | Kubernetes篇】Kubernetes 配置(十五)

它还有助于集群重新创建和恢复。 使用 YAML 而不是 JSON 编写配置文件。虽然这些格式几乎可以在所有场景中互换使用,但 YAML 往往更加用户友好。 建议相关对象分组到一个文件。...一、Secret Secret 对象类型用来保存敏感信息,例如密码、OAuth 令牌和 SSH 密钥。 将这些信息放在 secret 中比放在Pod的定义或者容器镜像来说更加安全和灵活。...Secret 是一种包含少量敏感信息例如密码、令牌或密钥的对象。用户可以创建 Secret,同时系统也创建了一些 Secret。...data 字段中所有键值都必须是 base64 编码的字符串。如果希望执行这种 base64 字符串的转换操作,你可以选择设置 stringData 字段,其中可以使用任何字符串作为其取值。...: secretName: mysecret 挂载方式的secretsecret变化的时候会自动更新(子路径引用除外)二、ConfigMap ConfigMap 来将你的配置数据和应用程序代码分开

59252

Kubernetes系列】第3篇 基础概念介绍(下)

v2-41cd4e0da53d456d5ee31a41ce490067_1200x500.jpg 9 DaemonSet 守护进程集 DaemonSet保证在特定或所有Node节点上都运行一个Pod实例...14 Secret 密钥 Sercert-密钥解决了密码、token、密钥等敏感数据的配置问题,而不需要把这些敏感数据暴露到镜像或者Pod Spec中。...有如下三种类型: Service Account:用来访问Kubernetes API,由Kubernetes自动创建,并且会自动挂载到Pod的 /run/secrets/http://kubernetes.io.../serviceaccount 目录中; Opaque:base64编码格式的Secret,用来存储密码、密钥等; http://kubernetes.io/dockerconfigjson:用来存储私有...ConfigMap跟secret很类似,但它可以更方便地处理包含敏感信息的字符串。

59740

Kubernetes运维之容器编排基础Pod编写

Pods的YAML编写 Pod 是可以在 Kubernetes创建和管理的、最小的可部署的计算单元。...(secret) k8s secrets用于存储和管理一些敏感数据,比如密码,token,密钥等敏感信息。...它把 Pod 想要访问的加密数据存放到 Etcd 中。然后用户就可以通过在 Pod 的容器里挂载 Volume 的方式或者环境变量的方式访问到这些 Secret 里保存的信息了。...Secret有三种类型 Opaque:base64 编码格式的 Secret,用来存储密码、密钥等;但数据也可以通过base64 –decode解码得到原始数据所有加密性很弱。...命令创建 用来创建用户docker registry认证的Secret,直接使用kubectl create命令创建即可,如下: kubectl create secret docker-registry

34110

基础设施即代码在 CICD 中必须具备的功能

不可变的版本控制,即使用单一代码库创建和删除基础设施。 在整个 CI/CD 过程中进行测试。 设置策略的能力。 管理安全性的能力。 基础设施即代码提供的不变性在 CI/CD 中非常重要。...根据 EMA 的数据,尽管竞争对手 Terraform 声称在市场份额上几乎是 Pulumi 的 10 倍,但 Pulumi 的市场份额增长速度约为 Terraform 的 2 至 3 倍。...另一方面, Pulumi 声称支持所有主要编程语言,因此提供了更多的选择自由和更直接的方式来为 CI/CD 和一般情况下进行基础设施规划。...Duffy 表示,生产力的提高可以“实际上是数量级的改变”,并补充说 Pulumi 可以在不到 15 行代码的情况下部署 Amazon Web Services 上的弹性 Kubernetes 服务集群...在会议之前,Pulumi 的市场副总裁 Aaron Kao 进行了一次演示,展示了如何使用基本的英语对话命令向 Pulumi Insights 提出查询,并获取有关跨多云环境部署的 Kubernetes

6510
领券