分享微软刚开源的Retina:云原生网络可观察性平台

Retina 是一个开源的 Kubernetes 网络可观察性平台,旨在为应用健康、网络健康和安全提供集中化的监控中心。它支持多云环境,能够收集可定制的遥测数据,并将其导出到多种存储选项中(如 Prometheus、Azure Monitor 等),同时支持多种可视化工具(如 Grafana、Azure Log Analytics 等)。

基础知识点

  1. eBPF技术:Retina 利用 eBPF(extended Berkeley Packet Filter)技术来实现网络可观察性。这是一种高效的数据包捕获和分析方法,能够在不影响系统性能的情况下提供详细的网络流量信息。

  2. 可定制遥测:Retina 允许用户根据需要定制遥测数据的收集和导出。这意味着用户可以选择哪些指标需要监控,并将这些数据发送到不同的存储系统中。

  3. 云环境支持:Retina 支持多种云环境和操作系统(如 Linux、Windows、Azure Linux),使其在不同部署场景中都能有效工作。

主要功能

  • 指标监控:Retina 提供可行的、符合行业标准的 Prometheus 指标,帮助用户实时监控网络和应用的健康状况。
  • 数据包捕获:通过流线化的数据包捕获功能,用户可以深入分析网络流量,诊断问题。

安装和使用

1. 使用 Helm 安装 Retina

首先,获取最新的 Retina 版本:

bash 复制代码
VERSION=$(curl -sL https://api.github.com/repos/microsoft/retina/releases/latest | jq -r .name)

然后,使用 Helm 安装 Retina:

bash 复制代码
helm upgrade --install retina oci://ghcr.io/microsoft/retina/charts/retina \
    --version $VERSION \
    --set image.tag=$VERSION \
    --set operator.tag=$VERSION \
    --set logLevel=info \
    --set enabledPlugin_linux="[dropreason,packetforward,linuxutil,dns]"

2. 安装 Retina CLI

使用 Krew 安装 Retina CLI:

bash 复制代码
kubectl krew install retina

验证安装:

bash 复制代码
kubectl retina

3. 创建数据包捕获

使用 CLI 创建数据包捕获:

bash 复制代码
kubectl retina capture create --pod-selectors app=my-app

示例代码

Prometheus 配置示例

在安装完 Retina 后,需要配置 Prometheus 来收集指标。以下是一个基本的 Prometheus 配置示例:

yml 复制代码
# prometheus.yml
global:
  scrape_interval: 15s

scrape_configs:
  - job_name: 'retina'
    static_configs:
      - targets: ['retina-prometheus:9090']

Grafana 可视化

在 Grafana 中创建一个仪表盘来可视化这些指标。首先,添加一个 Prometheus 数据源,然后创建一个新面板,选择需要展示的指标。

为什么选择 Retina?

Retina 提供了灵活的网络可观察性解决方案,允许用户按需调查网络问题,并持续监控集群。它支持多种云环境和操作系统,使其适用于广泛的部署场景。

相关推荐
回家路上绕了弯8 分钟前
AgentScope Harness 深度实战:让Java智能体从“Demo可用”走向“生产可用”
后端
卷心菜投手ovo14 分钟前
RAG 为什么引用总是对不上?
后端·github
foggyprojects15 分钟前
动态 SQL 模板里,权限条件为什么要注入而不是散落在业务代码里
后端
Hommy8827 分钟前
【剪映小助手】图片处理接口
开源·github·aigc·剪映小助手·视频剪辑自动化
无风听海38 分钟前
ASP.NET Core .NET 10 错误响应体系全景:从 BadRequest 到编译器基础设施
后端·asp.net·.net
文心快码BaiduComate39 分钟前
从个人效能到组织资产:文心快码企业版Agent Hub上线,提升团队AI编程效能
前端·后端·程序员
雪隐1 小时前
个人电脑玩AI00-前言
人工智能·后端
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题 第89题】【Mysql篇】第19题:Hash 索引和 B+ 树索引的区别?它们在使用方面的区别?
java·数据库·mysql·面试·哈希算法
我是一颗柠檬2 小时前
【Java后端技术亮点】动态路由权限(按钮级权限),细粒度控制到按钮级别
java·开发语言·后端·状态模式
前端Hardy2 小时前
CSS 动画真的比 JS 快?Josh Comeau 做了组实验,结果跟直觉不一样
前端·javascript·后端