写点什么

如何通过 Kubernetes 网络策略隔离 1500 个微服务

  • 2020-01-19
  • 本文字数:1184 字

    阅读完需:约 4 分钟

如何通过Kubernetes网络策略隔离1500个微服务

Monzo 安全团队撰文分享了他们实现 Kubernetes 网络策略的经历,该策略通过 Calico 的 API 为 1500 个微服务提供了隔离。


Monzo 是一家面向移动端的数字银行,它们在 AWS 上运行其核心基础设施。除了使用Kubernetes托管其微服务外,Monzo 还使用Apache Cassandra 作为主要数据库,使用 Apache Kafka 进行消息传递,并使用 Go 实现了其大部分程序代码。Monzo 安全团队将采用零信任网络作为他们的目标之一。零信任平台的原则是,网络内外的任何一个实体都是不被信任的,要访问私有信息必须要经过验证。Monzo 后端的每个服务只允许访问一个经过预先批准的服务列表。Monzo 大约拥有 1500 个服务,超过 9300 个服务间的交互,这也让该任务变得非常困难。在构建了一个通过分析代码来派生策略的自定义工具集之后,Monzo 团队在 Kubernetes 上使用了针对 Calico 的网络策略来提供隔离。


团队首先通过隔离一个服务来测试他们的初步方案。他们编写了一个名为 rpcmap 的自定义工具,这个工具可以通过分析静态代码来发现服务之间的依赖关系。根据 Monzo 后端工程师Jack Kleeman的说法,他们在集成测试或运行时选择静态分析的方式而不是观察的方式,主要是因为:


Monzo 有很多代码路径,没有一个可以涵盖所有内容的集成测试。在运行时,某项服务很少被调用并不意味着它从不会被调用;一间银行可以有一些每年只运行一次的服务进程。


规则必须按照可管理和可读的方式存储,而且不能破坏现有的服务。Monzo 安全团队采用了 Kubernetes 的 NetworkPolicy 来执行规则探测,并使用Calico网络插件来实现网络策略。这种初始方法在可测试性方面非常脆弱,并把维护规则列表的责任交由管理调用服务的团队负责。另一个引入的缺点就是开发团队必须手动编辑 Kubernetes 的配置文件。


为解决这些问题,Kleeman 说:“跟 Calico 社区讨论了网络策略的测试问题后,我们发现可以使用 Calico 的一些无法被 Kubernetes 访问的特性来测试我们的策略。”其中的一个特性允许流量访问网络策略通常不允许的内容,随后记录下来这种情况。Kubernetes网络策略通常采用选择器和标签的方式,在没有采用任何策略的时候,Kubernetes 允许 pod 之间的所有通信。Monzo 将他们的策略配置在最后运行,并监控网络流量来确定哪些服务会丢失数据包。


此后,团队将服务允许的流量列表切换为调用服务的一个属性,而不是目标服务的属性。服务通过标签声明它们在策略的入口(ingress)规范中需要访问到的服务。针对那些调用大量其他服务的服务,例如监控服务,则会按照“服务类型”进行分组,按照这样的准则,就没有必要列出每个服务了。rpcmap 被配置为每次提交时运行,部署管道把规则文件转换为服务标签。团队计划在未来使用服务网格而不是 CNI(容器网络接口)层来实现这一点,他们已经迁移到了一个使用 Envy 的自定义网格。


原文链接:


How Monzo Isolated Their Microservices Using Kubernetes Network Policies


2020-01-19 09:003345

评论

发布
暂无评论
发现更多内容

众所周知,配置即代码≠基础设置即代码

禅道项目管理

项目管理 DevOps 自动化测试 配置即代码 基础设置即代码

华为大咖说 | 从《庖丁解牛》谈项目经理的三重境界

华为云PaaS服务小智

项目管理 开发 华为云

华为云空间端云一致体验:重要数据随时随地在手边

最新动态

接入效率提升90%,华为云空间助力开发者高效实现应用数据同步

最新动态

华为云GeminiDB赋能迷你创想:轻松应对亿级月活玩家

最新动态

Java实现零拷贝

极客罗杰

探索未来网络安全的新篇章:火绒安全与 OpenVINO™ 的协同创新

Geek_2d6073

【测试中的人工智能】自学活动一:理论知识学习

QE_LAB

人工智能 AI 测试

mac电脑好用的防火墙:Radio Silence for mac 激活版

你的猪会飞吗

mac软件下载 Mac电脑软件

DataWorks重磅推出全新资源组2.0,实现低成本灵活付费和动态平滑扩缩容

阿里云大数据AI技术

sql 大数据 阿里云 Serverless Dataworks

数字指纹在区块链上如何生成和验证

dappweb

区块链 ao

小鲤AI志愿填报助手:一键探索最适合你的大学专业

Geek_1ef48b

蓝易云 - nginx教程:upstream的两种配置方式

百度搜索:蓝易云

nginx HTTP 云服务器 upstream FastCGI

蓝易云 - nginx教程:配置项add_header Access-Control-Allow-Origin *的含义

百度搜索:蓝易云

nginx Linux 运维 CORS 云服务器

2024年全球零信任发展趋势

芯盾时代

网络安全 iam 统一身份认证 零信任

智能化改造助力企业高质量发展

天津汇柏科技有限公司

智能化 高质量发展

在版权保护中区块链如何提高效率

dappweb

区块链 ao

使用 Swift 6 语言模式构建 Swift 包

Swift社区

swift 企业号2024年6月PK榜

蓝易云 - docker教程:nginx.conf配置文件示例

百度搜索:蓝易云

nginx Docker 服务器 云服务器 高防服务器

基于STM32+华为云IOT设计的智能窗帘控制系统

DS小龙哥

6 月 优质更文活动

作为独立创作者的一点感想

zhumingwu

蓝易云 - nginx教程:proxy_pass指令后边有没有“/”的区别

百度搜索:蓝易云

nginx 运维 前端 云服务器 proxy_pass

小浣熊家族 X InfoQ 写作社区有奖征文大赛获奖名单公示

InfoQ写作社区官方

热门活动

Toco x Databend:Databend Cloud 如何满足 Web3 大数据服务的严苛考验?

Databend

如何通过Kubernetes网络策略隔离1500个微服务_容器_Hrishikesh Barua_InfoQ精选文章