引入Jaeger——扩展

2023-11-06 02:38
文章标签 扩展 引入 jaeger

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

Jaeger是收集全链路跟踪的信息,在Jaeger收集的信息中,有请求的url信息,有每个请求的时间间隔,借助这些信息可以进行报警,比如一次较长的请求,或者是某些请求的次数和先后等。不管报警的业务规则是什么,首先得收集Jaeger中的信息。

Jaeger有api可以提供这些信息,比如

/api/services,获取所有服务

/api/traces?service={servicename}获取该服务下的所有跟踪

/api/traces/{traceid}获取某个跟踪的信息等

/api/traces?end={endtime}&limit={20}&lookback={1h}&service={servicename}&start={starttime}按条件查询跟踪信息等api

下面代码定义Jaeger中的实体类,类中的属性可以根据自己的型业务规则收集,这里定义不完整

using System.Collections.Generic;namespace JaegerAlert
{/// <summary>/// 服务报警/// </summary>public class AlertList{public string ServiceName { get; set; }public List<AlertItem> Alerts { get; set; }}/// <summary>/// 报警条目/// </summary>public class AlertItem{public string TraceID { get; set; }public long StartTime { get; set; }public long Duration { get; set; }public string Method { get; set; }public string Operation { get; set; }}/// <summary>/// 服务数据/// </summary>public class ServicesData{public string[] Data { get; set; }public int Total { get; set; }public int Limit { get; set; }public int Offset { get; set; }}/// <summary>/// 跟踪数据/// </summary>public class TracesData{public TracesItem[] Data { get; set; }public int Total { get; set; }public int Limit { get; set; }public int Offset { get; set; }}/// <summary>/// 跟踪条目/// </summary>public class TracesItem{public string TraceID { get; set; }public Span[] Spans { get; set; }}/// <summary>/// Span/// </summary>public class Span{public string TraceID { get; set; }public string SpanID { get; set; }public bool IsAlertMark => TraceID == SpanID;public int Flags { get; set; }public string OperationName { get; set; }public long StartTime { get; set; }public long Duration { get; set; }public Tag[] Tags { get; set; }}/// <summary>/// Tag/// </summary>public class Tag{public string Key { get; set; }public string Type { get; set; }public string Value { get; set; }}
}

这里简单进行了收集,转换成了自己的数据集合,方便对接自己的报警平台:

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;namespace JaegerAlert.Controllers
{[ApiController][Route("[controller]")]public class HomeController : ControllerBase{private readonly IHttpClientFactory _clientFactory;private readonly ILogger<HomeController> _logger;public HomeController(ILogger<HomeController> logger, IHttpClientFactory clientFactory){_clientFactory = clientFactory;_logger = logger;}[HttpGet]public async Task<IEnumerable<AlertList>> Get(){_logger.LogInformation("获取警报列表");return await GetServices();}/// <summary>/// 获取所有服务/// </summary>/// <returns></returns>async Task<IEnumerable<AlertList>> GetServices(){var service = await GetJaegerServices();var services = new List<AlertList>();foreach (var serviceName in service.Data){if (serviceName == "jaeger-query"){continue;}var alerts = new List<AlertItem>();var tracesModels = await GetJaegerTraces(serviceName);foreach (var traces in tracesModels.Data){foreach (var span in traces.Spans){if (span.IsAlertMark){var method = span.Tags.SingleOrDefault(s => s.Key == "http.method")?.Value;var operation = span.Tags.SingleOrDefault(s => s.Key == "http.url")?.Value;alerts.Add(new AlertItem { TraceID = traces.TraceID, Duration = span.Duration, Method = method, Operation = operation, StartTime = span.StartTime });}}}services.Add(new AlertList() { ServiceName = serviceName, Alerts = alerts });}return services;}/// <summary>/// 获取服务下的跟踪条目/// </summary>/// <param name="serviceName"></param>/// <returns></returns>async Task<TracesData> GetJaegerTraces(string serviceName){using var client = _clientFactory.CreateClient("Jaeger");var request = new HttpRequestMessage(HttpMethod.Get, $"/api/traces?service={serviceName}");using var response = await client.SendAsync(request);if (response.IsSuccessStatusCode){var jsonString = await response.Content.ReadAsStringAsync();var traces = Newtonsoft.Json.JsonConvert.DeserializeObject<TracesData>(jsonString);return traces;}else{return new TracesData();}}/// <summary>/// 获取服务/// </summary>/// <returns></returns>async Task<ServicesData> GetJaegerServices(){using var client = _clientFactory.CreateClient("Jaeger");var request = new HttpRequestMessage(HttpMethod.Get, "/api/services");using var response = await client.SendAsync(request);if (response.IsSuccessStatusCode){var jsonString = await response.Content.ReadAsStringAsync();var service = Newtonsoft.Json.JsonConvert.DeserializeObject<ServicesData>(jsonString);return service;}else{return new ServicesData();}}}   
}

请求结果:

收集到数据后,就可以应用到报警平台上,如果报警平台有api,可以进行调用处理;还可以把这些数据推送到时序数据库中,如InfluxDB,再通过Grafana展示出来,进行实时展时跟踪,关于跟踪的细节和业务规则有关系,如果以后工作中遇到这类处理,到时再追加一篇博文进行细说。

这篇关于引入Jaeger——扩展的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/353999

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

PHP7扩展开发之数组处理

前言 这次,我们将演示如何在PHP扩展中如何对数组进行处理。要实现的PHP代码如下: <?phpfunction array_concat ($arr, $prefix) {foreach($arr as $key => $val) {if (isset($prefix[$key]) && is_string($val) && is_string($prefix[$key])) {$arr[

PHP7扩展开发之字符串处理

前言 这次,我们来看看字符串在PHP扩展里面如何处理。 示例代码如下: <?phpfunction str_concat($prefix, $string) {$len = strlen($prefix);$substr = substr($string, 0, $len);if ($substr != $prefix) {return $prefix." ".$string;} else

PHP7扩展开发之类型处理

前言 这次,我们将演示如何在PHP扩展中如何对类型进行一些操作。如,判断变量类型。要实现的PHP代码如下: <?phpfunction get_size ($value) {if (is_string($value)) {return "string size is ". strlen($value);} else if (is_array($value)) {return "array si

PHP7扩展开发之依赖其他扩展

前言 有的时候,我们的扩展要依赖其他扩展。比如,我们PHP的mysqli扩展就依赖mysqlnd扩展。这中情况下,我们怎么使用其他扩展呢?这个就是本文讲述的内容。 我们新建立一个扩展,名字叫 demo_dep , 依赖之前的say扩展。 在demo_dep扩展中,我们实现demo_say方法。这个方法调用say扩展的say方法。 代码 基础代码 确保say扩展的头文件正确安装到了php

PHP7扩展开发之函数方式使用lib库

前言 首先说下什么是lib库。lib库就是一个提供特定功能的一个文件。可以把它看成是PHP的一个文件,这个文件提供一些函数方法。只是这个lib库是用c或者c++写的。 使用lib库的场景。一些软件已经提供了lib库,我们就没必要再重复实现一次。如,原先的mysql扩展,就是使用mysql官方的lib库进行的封装。 在本文,我们将建立一个简单的lib库,并在扩展中进行封装调用。 代码 基础

PHP7扩展开发之对象方式使用lib库

前言 上一篇文章,我们使用的是函数方式调用lib库。这篇文章我们将使用对象的方式调用lib库。调用代码如下: <?php $hello = new hello(); $result = $hello->get(); var_dump($result); ?> 我们将在扩展中实现hello类。hello类中将依赖lib库。 代码 基础代码 这个扩展,我们将在say扩展上增加相关代码。sa

PHP7扩展开发之流操作

前言 啥是流操作?简单来讲就是对一些文件,网络的IO操作。PHP已经把这些IO操作,封装成流操作。这节,我们将使用PHP扩展实现一个目录遍历的功能。PHP示例代码如下: <?phpfunction list_dir($dir) {if (is_dir($dir) === false) {return;} $dh = opendir($dir);if ($dh == false) {ret