当前位置: 首页 > article >正文

Kubernetes 安全加固清单:从 RBAC 到 etcd 加密的生产实践

在云原生时代Kubernetes 已成为容器编排的事实标准但默认配置下的 K8s 并不安全。一次错误的 RBAC 权限配置、一个暴露的 etcd 端口、或者一个特权模式的 Pod都可能成为攻击者的入口。本文从认证授权、Pod 安全、网络隔离、数据加密四个维度整理一份可直接落地的加固清单。一、RBAC最小权限是铁律RBAC基于角色的访问控制是 K8s 权限管理的核心。很多人图省事给 ServiceAccount 直接绑定cluster-admin角色这在测试环境可以但生产环境等于裸奔。最小权限原则的正确做法是先定义应用实际需要的权限再精确授予。以下是一个典型前端应用只读场景的 Role 示例apiVersion:rbac.authorization.k8s.io/v1kind:Rolemetadata:namespace:defaultname:frontend-read-onlyrules:-apiGroups:[]resources:[configmaps,secrets]resourceNames:[app-config,db-credentials]# 精确到具体资源名verbs:[get,list]如果你需要跨命名空间授权使用RoleBinding本命名空间或ClusterRoleBinding集群级别。ClusterRoleBinding要格外谨慎绑定的cluster-admin角色要确认 subject 只能是必要的 ServiceAccount不要用system:authenticated这种通配符apiVersion:rbac.authorization.k8s.io/v1kind:ClusterRoleBindingmetadata:name:monitoring-readersubjects:-kind:ServiceAccountname:prometheusnamespace:monitoringroleRef:kind:ClusterRolename:cluster-monitoring-viewapiGroup:rbac.authorization.k8s.io建议定期用kubectl auth can-i --list --assystem:serviceaccount:ns:sa检查每个 ServiceAccount 的实际权限清理无用绑定。二、Pod Security Standards别让容器拥有不该有的能力K8s 从 1.25 起将 Pod Security Policy 替换为 Pod Security StandardsPSS通过命名空间标签定义三个级别的安全策略privileged最高权限、baseline最低要求、restricted生产推荐。将命名空间标记为restricted级别apiVersion:v1kind:Namespacemetadata:name:productionlabels:pod-security.kubernetes.io/enforce:restrictedpod-security.kubernetes.io/enforce-version:latestpod-security.kubernetes.io/warn:restrictedpod-security.kubernetes.io/warn-version:latestrestricted策略会强制要求禁止特权模式、禁止以 root 运行、只允许受控的 capabilities、必须使用只读根文件系统。例如一个合法的 non-root 容器 Pod specsecurityContext:runAsNonRoot:truerunAsUser:10000seccompProfile:type:RuntimeDefaultallowPrivilegeEscalation:falsereadOnlyRootFilesystem:truecapabilities:drop:-ALL如果你需要在 Pod 中挂载特定 capabilities比如CAP_NET_BIND_SERVICE用于绑定低端口要逐个声明而非全部放开capabilities:add:-NET_BIND_SERVICEdrop:-ALL三、网络策略默认拒绝按需放行K8s 网络模型默认是全通行的同一集群内的 Pod 可以自由互相访问。攻击者一旦拿到某个 Pod往往能横向渗透到整个集群。解决方案是给每个命名空间设置默认拒绝规则再按需放行。默认拒绝所有入站流量apiVersion:networking.k8s.io/v1kind:NetworkPolicymetadata:name:default-deny-ingressnamespace:productionspec:podSelector:{}policyTypes:-Ingress放行 Web 层访问后端服务apiVersion:networking.k8s.io/v1kind:NetworkPolicymetadata:name:allow-web-to-apinamespace:productionspec:podSelector:matchLabels:app:api-serveringress:-from:-podSelector:matchLabels:app:web-frontendports:-protocol:TCPport:8080需要注意的是网络策略需要有 CNI 插件支持才能生效Flannel 默认不支持推荐使用 Calico、Cilium 或 WeaveNet。四、Secrets 管理别把敏感信息明文存放Kubernetes Secrets 默认只是 Base64 编码未经加密存储在 etcd 中任何有 etcd 访问权限的人都能直接读取。最小化处理是开启 Secrets 的加密apiVersion:apiserver.config.k8s.io/v1kind:EncryptionConfigurationresources:-resources:-secretsproviders:-aescbc:keys:-name:key1secret:base64-encoded-32-byte-key-identity:{}# 回退provider不能删然后在 kube-apiserver 启动参数中指定配置--encryption-provider-config/etc/kubernetes/enc/encryption-config.yaml生产环境中更推荐使用外部 Secrets 管理方案HashiCorp Vault通过 CSI 驱动挂载、AWS Secrets Manager EKS IAM Roles for Service Accounts、或者 Mozilla SOPS 配合 KMS 加密。这类方案的优势在于 Secrets 不会出现在 K8s API 层审计日志也更完整。日常使用中还要注意不要用kubectl create secret generic时直接暴露明文用--from-literal或--from-file不要在 Pod 环境变量中引用 Secrets 而是使用 volume 挂载这样重启才能感知变更。五、etcd 加密护住 K8s 的数据心脏etcd 存储了 K8s 整个集群的状态数据包括 Secret、RBAC 配置、Pod 定义等。一旦 etcd 被攻破攻击者就拿到了整个集群。etcd 加密是最后一道防线。开启 etcd 数据加密静态加密# 生成一个 32 字节的加密 key注意是原始字节不是 base64 字符串ENCRYPTION_KEY$(head-c32/dev/urandom|base64)# 写入 encryption configcat/etc/kubernetes/enc/encryption-config.yamlEOF apiVersion: apiserver.config.k8s.io/v1 kind: EncryptionConfiguration resources: - resources: - secrets providers: - aescbc: keys: - name: key1 secret:${ENCRYPTION_KEY}- identity: {} EOF同时确保 etcd 的通信也是 TLS 加密的启动参数大致如下etcd\\--cert-file/etc/kubernetes/pki/etcd/server.crt\\--key-file/etc/kubernetes/pki/etcd/server.key\\--client-cert-authtrue\\--trusted-ca-file/etc/kubernetes/pki/etcd/ca.crt\\--listen-client-urlshttps://127.0.0.1:2379etcd 数据目录的磁盘加密也不能忽视生产环境建议用 LUKS 或云厂商的加密磁盘防止物理磁盘泄露导致的数据暴露。加固检查清单以下是生产级 K8s 集群上线前必须通过的检查项kube-apiserver 开启--anonymous-authfalse禁止匿名访问kube-apiserver 开启--authorization-modeRBAC,Nodekube-apiserver 关闭不爱用的服务端口如 kubelet HTTPS API 不暴露在外网etcd 仅监听本地或通过安全网络访问不对外网暴露 2379/2380 端口所有命名空间设置了 Pod Security Standards 标签ServiceAccount 不绑定 cluster-admin遵循最小权限Secrets 开启静态加密aescbc 或更好的 KMS 插件etcd 通信使用 TLS不使用 insecure 模式网络策略至少在关键命名空间production、data启用默认拒绝定期审计日志kubectl get events --all-namespaces --watch安全加固不是一次性工程而是持续运营的过程。建议配合 Falco 做运行时威胁检测配合 OPA Gatekeeper 做策略即代码Policy-as-Code用自动化工具保障每次部署都不违背安全基线。防守的深度取决于攻击者的投入成本。做好这些基础加固足以让大多数自动化扫描工具和初级攻击者止步。

相关文章:

Kubernetes 安全加固清单:从 RBAC 到 etcd 加密的生产实践

在云原生时代,Kubernetes 已成为容器编排的事实标准,但默认配置下的 K8s 并不安全。一次错误的 RBAC 权限配置、一个暴露的 etcd 端口、或者一个特权模式的 Pod,都可能成为攻击者的入口。本文从认证授权、Pod 安全、网络隔离、数据加密四个维…...

在macOS上运行Windows应用:为什么传统方案失败而Whisky成功

在macOS上运行Windows应用:为什么传统方案失败而Whisky成功 【免费下载链接】Whisky A modern Wine wrapper for macOS built with SwiftUI 项目地址: https://gitcode.com/gh_mirrors/wh/Whisky 你是否曾经面临这样的困境:手头有一款必须使用的W…...

AssetStudio实战指南:解锁Unity游戏资源的完整解决方案

AssetStudio实战指南:解锁Unity游戏资源的完整解决方案 【免费下载链接】AssetStudio AssetStudio - Based on the archived Perfares AssetStudio, I continue Perfares work to keep AssetStudio up-to-date, with support for new Unity versions and additional…...

矩阵中的“对角线强迫症”:如何优雅地判断Toeplitz矩阵?

举个栗子 🌰 例子1: 矩阵: [6, 7, 8] [4, 6, 7] [1, 4, 6]它的对角线分别是:[6,6,6], [7,7], [8], [4,4], [1],每条对角线上的数字都相同,所以它是Toeplitz矩阵 ✅ 例子2: 矩阵: …...

钉钉数字化转型避坑指南:这10个“雷区”90%企业都踩过

钉钉数字化转型避坑指南:这10个“雷区”90%企业都踩过在数字经济浪潮下,企业数字化转型已从“可选项”变为“生存必修课”。而钉钉作为国内领先的企业数字化平台,凭借其开放生态、低代码能力和丰富应用,成为众多企业转型的首选基座…...

macOS微信防撤回终极指南:3步安装WeChatIntercept插件

macOS微信防撤回终极指南:3步安装WeChatIntercept插件 【免费下载链接】WeChatIntercept 微信防撤回插件,一键安装,仅MAC可用,支持v3.7.0微信 项目地址: https://gitcode.com/gh_mirrors/we/WeChatIntercept 还在为微信消息…...

基于Magisk挂载机制的Android HTTPS流量监控完整技术方案

基于Magisk挂载机制的Android HTTPS流量监控完整技术方案 【免费下载链接】httpcanary-magisk 项目地址: https://gitcode.com/gh_mirrors/ht/httpcanary-magisk 现代Android系统安全架构的演进为应用开发者带来了新的技术挑战,特别是在HTTPS流量监控领域。…...

内容做了一大堆,流量就是起不来?初创公司低成本获流的真实解法

内容做了一大堆,流量就是起不来?初创公司低成本获流的真实解法 我见过太多这样的团队:每周雷打不动三篇公众号,两条短视频,外加若干条推特,数据面板安安静静,后台没有咨询,评论区只…...

3分钟拯救你的B站视频:m4s-converter零转码转换完全指南

3分钟拯救你的B站视频:m4s-converter零转码转换完全指南 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 想象一下,你花了…...

ADAU1701(含A2B)的开发详解五:SigmaStudio实战技巧与模块高效应用

1. SigmaStudio模块查找的终极技巧 第一次打开SigmaStudio时,面对左侧密密麻麻的模块列表,我完全懵了。就像走进一个巨大的图书馆却找不到分类标签,ADI把200多个算法模块分散在30多个分类里,光Volume Controls下面就有12种音量调节…...

终极指南:如何用OpenBoardView免费开源工具轻松查看和分析PCB电路板文件

终极指南:如何用OpenBoardView免费开源工具轻松查看和分析PCB电路板文件 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView 你是否曾经需要查看.brd格式的PCB设计文件,却苦于没有昂贵的…...

Windows安卓应用安装器终极指南:3种方法实现跨平台无缝体验

Windows安卓应用安装器终极指南:3种方法实现跨平台无缝体验 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 在移动互联网时代,我们经常遇到这样…...

别再手动绑骨了!用Mixamo+Unity 2022,5分钟搞定二次元角色动画(附材质修复全流程)

二次元角色动画高效制作指南:Mixamo与Unity 2022的完美配合 在独立游戏开发领域,角色动画制作往往是耗时最长的环节之一。传统手动绑骨流程不仅需要专业技能,还会消耗大量时间成本。对于二次元风格或Low Poly风格的独立游戏开发者来说&#x…...

美颜SDK如何选择?直播APP开发最容易忽略的几个问题

这几年,直播行业的竞争已经从“有没有功能”,逐渐演变成了“用户体验够不够好”。很多团队在做直播APP时,往往会把重点放在推流、连麦、礼物、私域运营这些显性功能上,却忽略了一个对用户留存影响极大的核心模块——美颜SDK。尤其…...

京东自动评价工具:Python智能购物助手终极指南

京东自动评价工具:Python智能购物助手终极指南 【免费下载链接】jd_AutoComment 自动评价,仅供交流学习之用 项目地址: https://gitcode.com/gh_mirrors/jd/jd_AutoComment 想要轻松完成京东购物后的评价任务吗?jd_AutoComment 是一款基于Python开…...

别慌!Pygame里time.sleep()报错?用Clock.tick()轻松搞定(附完整代码示例)

Pygame时间控制革命:为什么Clock.tick()比time.sleep()更适合游戏开发 在Pygame游戏开发的世界里,时间控制是构建流畅游戏体验的核心要素。许多初学者在从Python标准库转向Pygame时,常常会本能地使用time.sleep()来控制游戏节奏,却…...

如何快速掌握LiteDB.Studio:面向初学者的LiteDB数据库终极GUI管理工具完整指南

如何快速掌握LiteDB.Studio:面向初学者的LiteDB数据库终极GUI管理工具完整指南 【免费下载链接】LiteDB.Studio A GUI tool for viewing and editing documents for LiteDB v5 项目地址: https://gitcode.com/gh_mirrors/li/LiteDB.Studio 在嵌入式数据库应用…...

正规全能艺术台制造厂:可靠厂商选择要点解析

正规全能艺术台制造厂选择指南:5大可靠厂商评估要点FAQ“选对全能艺术台制造厂,不是看广告多响,而是看这5个‘隐性指标’——合规资质、自研技术、服务体系、数据安全、内容迭代能力!”很多公共文化场馆在采购全能艺术台时&#x…...

STM32CubeMX生成代码后,Keil编译烧写的那些“隐藏”步骤与调试器避坑

STM32CubeMX生成代码后,Keil编译烧写的那些“隐藏”步骤与调试器避坑 当你用STM32CubeMX生成代码后,以为万事大吉,结果在Keil里编译烧写时却频频碰壁——这几乎是每个STM32开发者都会经历的“成人礼”。那些教程里一笔带过的“编译”、“烧写…...

为 Claude Code 配置 Taotoken 以解决访问不稳定与 Token 不足问题

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 为 Claude Code 配置 Taotoken 以解决访问不稳定与 Token 不足问题 Claude Code 作为一款强大的编程助手,其原生服务有…...

车载毫米波雷达性能验证(1)_基于雷达模拟器的目标检测精度与可靠性测试

1. 车载毫米波雷达性能验证的核心逻辑 第一次接触车载毫米波雷达测试时,我被各种专业术语搞得晕头转向。直到后来才发现,性能验证的本质就是回答两个问题:测什么和怎么测。这就像买手机要关注摄像头像素和跑分一样,雷达测试也要抓…...

英雄联盟国服换肤工具R3nzSkin完整使用指南:免费体验所有皮肤

英雄联盟国服换肤工具R3nzSkin完整使用指南:免费体验所有皮肤 【免费下载链接】R3nzSkin-For-China-Server Skin changer for League of Legends (LOL) 项目地址: https://gitcode.com/gh_mirrors/r3/R3nzSkin-For-China-Server 想要在英雄联盟国服中免费体验…...

使用VSCode无法登录Codex解决方法

登录时提示:Token exchange failed: token endpoint returned status 403 Forbidden: Country, region, or territory not supported确保魔法工具的连接模式是支持应用的,有的是只支持网站,切换成支持应用模式即可解决此问题。...

终极R3nzSkin换肤工具:英雄联盟国服免费皮肤自定义完整指南

终极R3nzSkin换肤工具:英雄联盟国服免费皮肤自定义完整指南 【免费下载链接】R3nzSkin-For-China-Server Skin changer for League of Legends (LOL) 项目地址: https://gitcode.com/gh_mirrors/r3/R3nzSkin-For-China-Server 你是否曾经羡慕别人拥有稀有皮肤…...

三步搞定Switch破解:大气层系统完整安装与配置指南

三步搞定Switch破解:大气层系统完整安装与配置指南 【免费下载链接】Atmosphere-stable 大气层整合包系统稳定版 项目地址: https://gitcode.com/gh_mirrors/at/Atmosphere-stable 大气层(Atmosphere)系统是当前最稳定、最安全的Ninte…...

FreeMove:拯救C盘空间的智能文件迁移工具,告别存储焦虑

FreeMove:拯救C盘空间的智能文件迁移工具,告别存储焦虑 【免费下载链接】FreeMove Move directories without breaking shortcuts or installations 项目地址: https://gitcode.com/gh_mirrors/fr/FreeMove 你是否曾因C盘爆满而被迫删除重要文件&…...

智元与宇树的机器人之争:全栈布局与低成本盈利,谁能笑到最后?

智元:押上一切,志在必成智元押上了资本、声誉,还有两位创始人最黄金的职业生涯,它没有借口和退路,必须成功。上半年的中国机器人圈,如同一场魔幻现实主义大戏。4月,人形机器人半程马拉松在北京亦…...

PPPoE协议全解析:从原理到实践,打通家庭宽带连接第一关

1. 项目概述:从“猫”到世界的旅程每次打开网页、刷起视频,你有没有想过,你家的宽带究竟是怎么连上互联网的?这背后其实是一场从你家客厅到全球数据中心的精密“接力赛”。而这场接力赛的第一棒,也是最关键的一棒&…...

当Cox回归的比例风险假定被违背时,除了时依协变量还能怎么办?

当Cox回归的比例风险假定被违背时的五维解决方案 在生存分析领域,Cox比例风险模型因其半参数特性和对基准风险函数形式不做假设的优势,成为医学研究、工程可靠性分析等领域的标配工具。但当这个金标准遇到比例风险假定(PH假定)被违背的情况时&#xff0c…...

Zotero Duplicates Merger终极教程:3步自动化清理文献重复项

Zotero Duplicates Merger终极教程:3步自动化清理文献重复项 【免费下载链接】ZoteroDuplicatesMerger A zotero plugin to automatically merge duplicate items 项目地址: https://gitcode.com/gh_mirrors/zo/ZoteroDuplicatesMerger 还在为Zotero文献库中…...