使用 Istio 缓解电信 5G IoT 微服务 Pod 架构的安全挑战

embedded/2024/9/25 21:22:28/

在 Kubernetes 集群中部署微服务在 5G 电信中至关重要。但是,它也带来了重大的安全风险。虽然防火墙规则和代理提供了初始安全性,但 Kubernetes 中的默认通信机制(例如未加密的网络流量和缺乏访问控制)本质上是不安全的。这种不安全性可能会危及敏感数据。因此,在每个微服务 Pod 中实施额外的安全措施不仅仅是一个建议,而是确保集群内安全通信的关键步骤。因此,需要在每个应用程序内进行额外的配置。

Istio 通过有效管理各个 5G 电信微服务 Pod 之间的通信,为这些挑战提供了强大的解决方案。借助其控制平面,Istio 会自动将 sidecar 代理注入各个微服务 pod,从而确保安全高效的通信。

让我们深入研究一下。

什么是 Istio?

Istio 是一个重要的开源服务网格,可与基于微服务的应用程序无缝集成,从而简化监控、管理以及实施性能和安全策略。它可以防止过载,限制未经授权的访问,并保护传输中的数据。其支持系统统一并确保微服务的平稳运行,显著简化其管理并确保轻松满足性能和安全性要求。

什么是 Sidecar 代理?

sidecar 代理是与 Kubernetes 微服务 Pod 一起运行的独立容器。它负责卸载 Istio 中所有应用程序所需的功能。sidecar 代理是 Istio 架构的一个强大组件,可拦截应用程序的传入和传出网络流量。它使电信运营商能够应用策略并利用上述弹性功能,并使运营商能够在与外界的接口点执行高级功能,从而展示 Istio 架构的功能。

建筑

Istio 架构的支柱主要由两个关键组件塑造,每个组件在其功能中都发挥着关键作用:

  1. 数据平面是 Istio 架构的关键部分,由一组代理(使用 Envoy 部署,Envoy 是一种分布式应用程序的开源代理)组成,这些代理作为 sidecar 容器与微服务一起运行。
  2. 控制平面是 Istio 架构中的决定性元素,它管理代理并决定它们的操作。让我们更详细地了解每个组件。它包括以下组件:
  • 试点:管理服务发现和流量。
  • Citadel:管理安全性并实现安全通信。
  • Galley:验证和分发配置资源。
  • Mixer:处理策略实施和遥测收集。
  • Sidecar Injector:自动将 Envoy sidecar 代理注入 Kubernetes pod 以方便集成。

控制平面

为了解释 Istio 架构的工作原理,我们将使用基于上述架构图的示例,使用 Microservice-A 和 Microservice-B 部署的 sidecar 代理确保了无缝高效的通信。 sidecar 代理拦截网络流量,使应用程序能够实施和实施策略、利用弹性功能并启用高级功能。

当微服务 A 向微服务 B 发送请求时,sidecar 代理会识别目的地,转发请求,并检查服务到服务的通信策略,以确定是否应根据安全性、性能和可靠性进行调用。此拦截、转发和检查过程可确保正确处理请求。如果请求通过,Microservice-B 会处理请求,准备响应,并通过网络将其发送回去,网络会被 sidecar 代理拦截并转发到客户端,然后转发到目标应用程序微服务 A。

了解 Istio 服务网格对 Kubernetes 微服务的重要性

Istio 服务网格在 Kubernetes 中是必不可少的。虽然 Kubernetes 管理微服务,但它不处理流量管理、访问策略或遥测数据收集。Istio 无需更改应用程序代码即可提供这些功能,使其成为使用 sidecar 容器管理 Kubernetes 中的微服务的有吸引力的解决方案。它可以在任何分布式环境中运行,为云或本地应用程序提供安全的解决方案。

Istio 支持 Kubernetes 发行版,包括 EKS 等托管服务和自我管理的集群。它还适用于不同的应用程序编排平台和所有微服务应用程序,包括无服务器架构

Istio 的优势

Istio 为 Kubernetes 和 Istio 兼容平台提供了几个关键优势:

  1. 安全:在微服务之间强制实施强身份验证和授权要求。
  2. 应用性能:在微服务之间高效路由流量并处理重试和故障转移。
  3. 可观察性:从各个微服务收集遥测数据,以便详细了解运行状况和性能。
  4. 故障 排除: 单独监控每个微服务,以识别和解决性能和安全问题。

总体而言,Istio 简化了基于微服务的现代应用程序的管理员管理。

配置 YAML(另一种标记语言)

Service Mesh Control Plane 管理代理以路由流量,为数据平面提供策略和配置,并授权管理员定义和配置各种服务。配置完成后,SMCP 会将必要的信息分发到服务网格的数据平面,从而允许代理动态调整其行为。

电信运营商可以使用以下配置安装和运行 SMCP(服务网格控制平面):

SMCP YAML

YAML

apiVersion: maistra.io/v2
kind: ServiceMeshControlPlane
metadata:name: full-installnamespace: istio-system
spec:version: v2.1techPreview:meshConfig:defaultConfig:concurrency: 8     # Adjust according to the needproxy:runtime:container:resources:requests:cpu: 500mmemory: 256Milimits:             # Adjust according to the needcpu: "1"memory: 1Gitracing:sampling: 10000 # 0.01% increments. 10000 samples 100% of tracestype: Jaegergateways:ingress: # istio-ingressgatewayservice:type: ClusterIPports:- name: status-portport: 15020- name: http2port: 80targetPort: 8080- name: httpsport: 443targetPort: 8443meshExpansionPorts: []egress: # istio-egressgatewayservice:type: ClusterIPports:- name: status-portport: 15020- name: http2port: 80targetPort: 8080- name: httpsport: 443targetPort: 8443additionalIngress:some-other-ingress-gateway: {}additionalEgress:some-other-egress-gateway: {}policy:type: Istiodtelemetry:type: Istiodaddons:grafana:enabled: truekiali:name: kialienabled: trueinstall: # install kiali CR if not availabledashboard:viewOnly: falseenableGrafana: trueenableTracing: trueenablePrometheus: truejaeger:name: jaeger-productioninstall:storage:type: Elasticsearchelasticsearch:nodeCount: 3redundancyPolicy: SingleRedundancyindexCleaner:enabled: truenumberOfDays: 7schedule: 55 23 * * *ingress:enabled: trueruntime:components:tracing.jaeger.elasticsearch: # only supports resources and image namecontainer:resources:limits:cpu: 1memory: 1Girequests:cpu: 500mmemory: 1Gipilot:deployment:autoScaling:enabled: trueminReplicas: 2maxReplicas: 2targetCPUUtilizationPercentage: 85pod:tolerations:- key: node.kubernetes.io/unreachableoperator: Existseffect: NoExecutetolerationSeconds: 60affinity:podAntiAffinity:requiredDuringScheduling:- key: istiotopologyKey: kubernetes.io/hostnameoperator: Invalues:- pilotcontainer:resources:limits:                # Adjust according to the needcpu: "1"memory: 1Gi
 

Service Mesh Member Roll 明确标识了与 Service Mesh 控制平面关联的项目。唯一情况下,卷中登记的项目会受到 control plane 的影响。将项目添加到成员卷会将其链接到特定的 control plane 部署。

电信运营商可以使用以下配置安装和运行 SMMR (Service Mesh Member Roll):

SMMR YAML

YAML

apiVersion: maistra.io/v1
kind: ServiceMeshMemberRoll
metadata:name: defaultnamespace: istio-system
spec:members:- <Micro services pods namespace>  #  namespace that needs be istio injected.
 

安装

1. 安装 SMCP (Service Mesh Control Plane),如下所示。

Service Mesh 控制平面

2. 按如下方式安装 SMMR (Service Mesh Member Roll)。

Service Mesh 成员卷

Istio 简化了 Kubernetes 环境中 5G 电信微服务 Pod 之间的通信,并支持跨不同平台的微服务架构的无缝连接、控制、监控和安全。它支持容器和虚拟机中的工作负载。

借助 Istio,电信 IoT 微服务 Pod 架构的未来看起来很有希望,并且具有更高的效率、安全性和可扩展性。


http://www.ppmy.cn/embedded/116833.html

相关文章

如何防止U盘资料被复制?(最全攻略来了,第一种你Get了吗?)

防止U盘资料被复制是一个涉及多个层面的策略。 以下是最全面的攻略&#xff0c;旨在帮助您确保U盘中的数据安全&#xff1a; 1. 使用加密软件 加密U盘&#xff1a;利用专业的加密软件&#xff08;如安企神、Verypt等&#xff09;对U盘进行全盘或分区加密。 这些软件可以确保只…

MySQL内存(Buffer Pool)

Buffer Pool MySQL 的数据存在磁盘&#xff0c;但是不能每次读取数据都从磁盘里去&#xff0c;这样磁盘IO太频繁&#xff0c;存在性能问题。 InnoDB设计了一个缓存池&#xff08;Buffer Pool&#xff09;&#xff0c;缓冲池在内存中。 默认配置Buffer Pool大小为128MB&#xf…

Lanterns (dp 紫 线段树 二分 维护dp)

Lanterns - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 让所有点被覆盖&#xff0c;那么状态可以设计成覆盖一段前缀&#xff0c;并且中间不允许出现断点 由于CF崩了&#xff0c;所以暂时没提交代码。 记f(i) 为前 i 个灯笼点亮的最长前缀。 由于答案具有保留性&#xff…

【第2章 开始学习C++】进入C++

文章目录 导语C语言输入和输出main( )函数作为接口的函数头C预处理器和iostream文件头文件名名称空间使用 cout 进行 C 输出控制符 endl 导语 首先介绍一个显示消息的简单C程序。 源代码中包含一些供读者阅读的注释&#xff0c; 这些注释都以 // 打头&#xff0c; 编译器将忽…

51单片机-系列-数码管中断和定时器

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 数码管 8051单片机的最小系统 电源&#xff08;5V&#xff09;复位电路晶振&#xff08;单片机的心脏&#xff09;如果要使用PO口&#xff0c;必须加4.7K-10K上拉电阻&#xf…

linux命令行快捷键

第一章 linux之帮助命令 第二章 linux命令行快捷键 文章目录 linux命令行快捷键 linux命令行快捷键 Tab 命令补全或文件补全Ctrlu 删除或剪切光标之前的命令Ctrla 将光标移动到命令行开头Ctrle 将光标移动到命令行结尾ctrlc 终止当前命令ctrll 清屏ctrly 粘贴ctrlu的内容 参考…

众数信科 AI智能体政务服务解决方案——AI法律助手

政务服务解决方案 AI法律助手 一款基于AI大模型的智能鼠标 搭裁“寻知AI法律助手” 众数信科AI智能体 产品亮点 能够结合全国各地案例数据 为用户提供法律咨询、文书生成、案例研判 类案推荐、法规检索等法律服务 同时结合Al office插件 具备AI智能办公、PPT生成等功能 …

gnome Files管理文件学习

Files文件夹页可以非常高效的使用&#xff0c;接下来介绍一些有用的快捷命令和tricks 首先是快捷键&#xff1a; **Ctrl T**Ctrl N**Ctrl WClose window or tab**Ctrl FSearch**Ctrl LEnter location**BackspaceGo Back to a Previous FolderCtrl Zoom inCtrl -Zoom outCtrl 0…