opentelemetry实践

2024-03-06 09:32
文章标签 实践 opentelemetry

本文主要是介绍opentelemetry实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

场景描述

根据 open-telemetry 提供的exampleshttps://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/examples/demo

假设我们有两个服务,一个是demo-server,一个是demo-client,demo-client会周期性调用demo-server,我们希望可以采集到demo-server与demo-client之间的监控数据,包括请求延迟和请求数统计(demo里面也提供了如何把数据接入到分布式调用链系统上,比如jaegre)

服务架构图

基于opentelemetry我们实现的架构图大概如下

如果是我们直接使用Promutheus的话,可能是如下的架构图

 

 

如果我们想Demo-Server和Demo-Client使用推数据的方式的话,可以使用PushGateway,如下

这里补充下,那这样的话,使用Opentelemetry的好处式啥呢?其实就是标准化了,比如我们现在想接入jaegre来做分布式调用链分析,如果有Opentelemetry的话,我们也是一样Demo-Server和Demo-Client直接上报给Opentelemetry Collector就可以了,也不用引入新的SDK;没有opentelemetry的话,我们就需要俩套SDK,而且也没有一个标准化

 

Docker 部署

Opentelemetry项目提供了一个docker-compose的启动方案,具体可以参考:https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/examples/demo

部署之后,我们可以通过访问promutheus,看到相应的数据收集

k8s 部署

基于官网提供的dmeo (https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/examples/demo),适配到k8s。

代码地址:https://github.com/khalid-jobs/khalid.project/tree/main/opentelemetry-k8s

为了方便,下面的服务暴露都使用nodePort进行暴露

1. 在k8s上搭建promutheus + grafna

cd promutheus_grafna
# 部署promutheus
kubectl apply -f prometheus-sa.yaml
kubectl apply -f prometheus-cm.yaml
kubectl apply -f prometheus-deployment.yaml
kubectl apply -f prometheus-service.yaml
# 部署grafna
kubectl apply -f grafna.yaml
kubectl apply -f grafna-service.yaml

2. 在k8s 部署collector

kubectl apply -f otel-collector/deploy.yaml

3. 部署demo-server 和 demo-client

# 部署demo-server
cd server
make image
kubectl apply -f deploy.yaml # 注意配置好节点和镜像地址
# 部署demo-client也是类似

4. promutheus收集collector

 

 

参考

1. Opentelemetry Collector的配置和使用 - charlieroro - 博客园 定义的推送

2. 例子说明:https://www.cnblogs.com/charlieroro/p/13883602.html (collector 包含了exporter之类的)

3. Getting Started | OpenTelemetry

4. promutheus+grafana

  • 部署 Prometheus 和 Grafana 到 k8s - WeihanLi - 博客园
  • K8s 部署 Prometheus + Grafana - LB477 - 博客园
  • How To Setup Prometheus Monitoring On Kubernetes Cluster [Tutorial]

这篇关于opentelemetry实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/779596

相关文章

Vue 2 项目中配置 Tailwind CSS 和 Font Awesome 的最佳实践举例

《Vue2项目中配置TailwindCSS和FontAwesome的最佳实践举例》:本文主要介绍Vue2项目中配置TailwindCSS和FontAwesome的最... 目录vue 2 项目中配置 Tailwind css 和 Font Awesome 的最佳实践一、Tailwind CSS 配置1. 安

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot 常用注解详解与使用最佳实践建议

《SpringBoot常用注解详解与使用最佳实践建议》:本文主要介绍SpringBoot常用注解详解与使用最佳实践建议,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、核心启动注解1. @SpringBootApplication2. @EnableAutoConfi

Redis实现分布式锁全解析之从原理到实践过程

《Redis实现分布式锁全解析之从原理到实践过程》:本文主要介绍Redis实现分布式锁全解析之从原理到实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景介绍二、解决方案(一)使用 SETNX 命令(二)设置锁的过期时间(三)解决锁的误删问题(四)Re

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三