signoz调研部署及log收集体验

news2025/1/11 6:59:59

这里是weihubeats,觉得文章不错可以关注公众号小奏技术,文章首发。拒绝营销号,拒绝标题党

背景

最近一直在调研监控、log收集,tracing相关的开源项目,以便使用。
前段时间一直调研使用的是skywalking。后来发现在log收集存储这一快skywalking使用的是elasticsearchelasticsearch存储相关的费用比较高,没有clickhouse更节约存储。skywalking社区也暂时不打算支持clickhouse存储
关于skywalking的存储相关的讨论可以在看看这个链接
https://github.com/apache/skywalking/discussions/9011

就是有一些公司已经落地skywalking支持clickhouse存储。
其次就是感觉skywalking搜集log的一些查询不太好用,所以就打算调研其他log组件。所以就调研到了signoz

signoz官网

  • signoz:https://signoz.io/

signoz可以做什么

  1. 监控应用程序指标,如延迟、每秒请求数、错误率
  2. 监控基础架构指标,如CPU利用率或内存使用率
  3. 跨服务跟踪用户请求
  4. 设置指标警报
  5. 收集log

工作原理

这里工作原理其实和skywalking差不太多。我们引用他们的官方架构图看看吧

  • OpenTelemetry采集器:从您的服务和应用程序收集遥测数据。
  • lickHouse:一个开源的高性能列式OLAP数据库管理系统。
  • 查询服务:前端和ClickHouse之间的接口
  • 前端:用户界面,内置于ReactJS和TypeScript。

部署

signoz支持多种方式部署

  • Docker Standalone
  • Docker Swarm
  • Kubernetes

测试我们使用Docker Standalone就好,线上一般使用Kubernetes

  1. 下载源码并进入deploy目录
git clone -b main https://github.com/SigNoz/signoz.git && cd signoz/deploy/
  1. 基于docker compose 部署
docker compose -f docker/clickhouse-setup/docker-compose.yaml up -d

如果没有安装docker可以执行如下命令安装
bash <(curl -SsL get.docker.com)

  1. 验证
docker ps

展示如下信息代表安装成功

CONTAINER ID   IMAGE                                          COMMAND                  CREATED          STATUS                    PORTS                                                                            NAMES
1ad413fc12aa   signoz/frontend:0.8.0                          "nginx -g 'daemon of…"   20 minutes ago   Up 20 minutes             80/tcp, 0.0.0.0:3301->3301/tcp, :::3301->3301/tcp                                frontend
419f7b440412   signoz/alertmanager:0.23.0-0.1                 "/bin/alertmanager -…"   20 minutes ago   Up 20 minutes             9093/tcp                                                                         clickhouse-setup_alertmanager_1
95f5fab00c3c   signoz/otelcontribcol:0.43.0-0.1               "/otelcontribcol --c…"   21 minutes ago   Up 21 minutes             0.0.0.0:4317-4318->4317-4318/tcp, :::4317-4318->4317-4318/tcp, 55679-55680/tcp   clickhouse-setup_otel-collector_1
c1640c215d10   signoz/otelcontribcol:0.43.0-0.1               "/otelcontribcol --c…"   21 minutes ago   Up 21 minutes             4317/tcp, 55679-55680/tcp                                                        clickhouse-setup_otel-collector-metrics_1
9db88c61f7fd   signoz/query-service:0.8.0                     "./query-service -co…"   21 minutes ago   Up 21 minutes (healthy)   8080/tcp                                                                         query-service
509ab96c5393   clickhouse/clickhouse-server:22.4-alpine       "/entrypoint.sh"         22 minutes ago   Up 21 minutes (healthy)   8123/tcp, 9000/tcp, 9009/tcp                                                     clickhouse-setup_clickhouse_1
eb7a2e23c0c0   grubykarol/locust:1.2.3-python3.9-alpine3.12   "/docker-entrypoint.…"   22 minutes ago   Up 21 minutes             5557-5558/tcp, 8089/tcp                                                          load-hotrod
f234b5cb4512   jaegertracing/example-hotrod:1.30              "/go/bin/hotrod-linu…"   22 minutes ago   Up 21 minutes             8080-8083/tcp                                                                    hotrod

服务器部署保证自己的3301, 43174318端口开放

访问web页面

如果是本地就是如下地址
http://localhost:3301/

如果是服务器就换成自己的ip地址

页面大致是这个样子

ui还是非常漂亮的

支持功能

  • 用户管理
  • Log 查询
  • 监控告警
  • traces

log收集

支持的收集方式还是非常多的

  • 支持直接收集kubernetes
  • 支持直接收集docker log
  • 支持sdk 收集log
  • 支持 log文件收集

我们这里以java agent的方式接入

SigNoz支持OpenTelemetry标准,所以我们使用OpenTelemetry的方式接入就可以了

OpenTelemetry是什么我们后续可以单独聊一聊

官方给我提供了一个spring boot项目

  • spring-petclinic:https://github.com/SigNoz/spring-petclinic

我们下载该项目
然后打包
执行

./mvnw package

然后执行启动命令

OTEL_LOGS_EXPORTER=otlp OTEL_EXPORTER_OTLP_ENDPOINT="http://0.0.0.0:4317" OTEL_RESOURCE_ATTRIBUTES=service.name=myapp java -javaagent:/path/opentelemetry-javaagent.jar -jar target/*.jar

这里由于我的SigNozspring-petclinic在同一个服务器,所以我的ip的士是0.0.0.0。具体大家可以填写自己的实际ip

启动成功会有如下log打印

之后我们随便访问一些接口制造一些log

log查询

左下的关键字支持直接选中查询

点击log可以查看log详情

报警

目前报警支持如下渠道

  • webhook
  • Slack

渠道配置我们可以在Setting配置

这里可以新增一个报警渠道

这里我们可以简单使用webhook:https://webhook.site
来测试报警

告警配置语法支持

目前报警配置支持三种语法

  1. Query Builder:查询生成器-这是DIY的方式来建立警报选择指标从下拉菜单。您还可以通过从仪表板中选择选项来设置筛选条件和分组条件
  2. PromQL:可以使用Prometheus查询语言来编写警报表达式,这些警报将在固定的时间间隔内进行评估。如果您在Prometheus中设置了警报,那么这种方法应该非常熟悉
  3. Clickhouse查询-您可以编写遵循SigNoz数据模型和格式的clickhouse查询。查询结果将用于评估警报阈值条件。此外,还可以使用查询结果生成标签和注释

总结

其实可以看到功能是非常完善的,比较满足线上环境log的收集监控报警

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ubuntu18编译内核源码,并调整版本号

​ 目标 下载ubuntu18 4.15.0-20-generic内核源码&#xff0c;默认情况下编译的内核版本会是4.15.17&#xff0c;我们需要调整版本号跟系统默认的一致&#xff0c;即4.15.0-20-generic 1 下载内核源码 sudo apt install linux-source-4.15.0 默认情况下&#xff0c;上面的…

苹果iOS 17新功能:iPhone激活Apple Watch铃声反向查找手表

苹果 Apple Watch 此前一直有查找 iPhone 的功能&#xff0c;用户可以点击表盘的电话图标&#xff08;或者长按&#xff09;来激活 iPhone 的铃声&#xff0c;从而找到附近的 iPhone 手机。 在最新的 iOS 17 测试版本中&#xff0c;苹果为 iPhone 也添加了这一功能的反向版本&a…

STM32速成笔记—串口通信

文章目录 一、什么是串口通讯二、串口通讯有什么用三、STM32的串口通信四、串口通信相关概念4.1 波特率4.2 全双工和半双工4.3 同步通信和异步通信 五、硬件连接六、串口通讯程序配置6.1 使能串口时钟和GPIO时钟6.2 初始化GPIO6.3 初始化串口参数6.4 使能串口6.5 串口接收中断6…

3ds MAX 多维材质

有的时候&#xff0c;我们想在一个图形中添加两个材质 比如我们绘制了一个球体&#xff0c;想要表示这是足球&#xff0c;但是没有黑白方块的贴图 除了绘制一个贴图外&#xff0c;我们可以用多维材质直接实现。 这里给茶壶对象的盖子和壶身设置两种贴图&#xff1a; 首先打…

MVI设计模式

一.各种框架对比 https://blog.csdn.net/qq_36390114/article/details/126160017 1. MVC&#xff08;Model-View-Controller&#xff09; 模型-视图-控制器 MVC的目的就是为了M和V代码分离&#xff0c;降低耦合性。 Model&#xff1a;数据来源&#xff0c;网络请求数据和数据…

DJ8-1 shell 的启动和终止、重定向、管道

目录 8.1 shell 的启动和终止 8.2 输入输出重定向 8.2.0 标准输入输出 8.2.1 输出重定向 > 8.2.2 输入重定向 < 8.2.3 常见输入输出重定向形式 8.2.4 标准错误输出重定向 8.3 管道 Linux 系统中的 shell 具有两大功能&#xff1a; 是一个命令解释器&…

express框架学习笔记

express简介 express是一个基于Node.js平台的极简的、灵活的WEB应用开发框架。express是一个封装好的工具包&#xff0c;封装了很多功能&#xff0c;便于我们开发WEB应用&#xff08;HTTP服务&#xff09; express使用 新建express文件夹新建文件test01.js&#xff0c;代码如…

特征点Features2D类介绍

文章目录 Features2D类介绍1. cv::AgastFeatureDetector2. cv::AKAZE3. cv::BRISK4. cv::FastFeatureDetector5. cv::GFTTDetector6. cv::KAZE7. cv::MSER8. cv::SimpleBlobDetector9. cv::StarDetector10. cv::SIFT11. cv::SURF12. cv::FastFeatureDetector13. cv::AgastFeatu…

leetcode2385. 感染二叉树需要的总时间(java)

感染二叉树需要的总时间 感染二叉树需要的总时间递归 dfs代码演示 二叉树专题 感染二叉树需要的总时间 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;https://leetcode.cn/problems/amount-of-time-for-binary-tree-to-be-infected 给你一棵二叉树的…

每日一练 | 华为认证真题练习Day60

1、启用GRE的keepalive功能后&#xff0c;GRE隧道的本端会周期性的每10s向对端发送一次keepalive报文。 A. 对 B. 错 2、AAA协议是RADIUS协议。 A. 对 B. 错 3、路由器Radius信息配置如下&#xff1a;下列说法正确的有&#xff1f;&#xff08;多选&#xff09; A. 计费服务…

[Spring Cloud]:学习笔记·(一)

文章目录 摘要1 认识微服务1.1 单体架构与分布式架构1.2 分布式架构与微服务1.3 微服务架构 摘要 摘要&#xff1a;分布式&#xff1b;微服务&#xff1b;springcloud 1 认识微服务 1.1 单体架构与分布式架构 架构方式解释优点缺点单体架构将业务所有功能集中在一个项目中开…

java从入门到起飞(二)——运算符

目录 前提——运算符概念算数运算符注意事项&#xff1a;字符的“”操作字符串的“”操作 赋值运算符注意事项&#xff1a; 自增自减运算符注意事项&#xff1a; 关系运算符注意事项&#xff1a; 逻辑运算符短路逻辑运算符注意事项&#xff1a; 三元运算符计算规则&#xff1a;…

OpenCV Mat类

文章目录 Mat类Mat类数据类型读取Mat类支持的运算OpenCV Mat数据类型指针ptr的使用多维矩阵创建 Mat类 Mat类数据类型读取 S 有符号整型 U 无符号整型 F 浮点型CV_8U - 8位无符号整数&#xff08;0…255&#xff09;CV_8S - 8位有符号整数&#xff08;-128…127&#xff…

Python基础(1)——Python简介

Python基础&#xff08;1&#xff09;——Python简介 文章目录 Python基础&#xff08;1&#xff09;——Python简介目标Python介绍Python版本总结 目标 了解PythonPython的应用领域Python的版本 Python介绍 Python是时下最流行、最火爆的编程语言之一&#xff0c;具体原因如…

SAP从入门到放弃系列之BOM组-Part1

目录 BOM组两种模式&#xff1a; 创建BOM的方式 方式一&#xff1a;直接在每个工厂分别创建BOM。 方式二&#xff1a;创建BOM组&#xff0c;然后每个工厂参考创建 方式三&#xff1a;创建BOM组&#xff0c;每个工厂参考创建&#xff0c;针对有特殊的工厂复制BOM组后进行调…

人机交互学习-9 以用户为中心的设计

以用户为中心的设计 以用户为中心的设计思想工程设计过程的三个假设以人为本设计思想三个方面的假设以用户为中心的设计四原则UDC项目包含的方法 用户参与设计用户参与的重要性选择哪些用户&#xff1f;为什么要让用户参与&#xff1f; 用户参与的形式参与式设计PICTIVECARD 理…

Nacos-手写注册中心基本原理

本文已收录于专栏 《中间件合集》 目录 概念说明需求分析核心功能代码实现AService模块BService模块NacosService模块NacosSDK模块 注意事项总结提升 概念说明 注册中心是微服务架构中的纽带&#xff0c;类似于“通讯录”&#xff0c;它记录了服务和服务地址的映射关系。在分布…

香蕉派(Banana Pi) BPI-M2 Zero 评测试,与树莓派 Zero同尺寸的开发板

Banana Pi M2 Zero 是一款微型计算机&#xff0c;配备四核处理器并内置 Wi-Fi 和蓝牙。这是一款非常适合基本计算任务甚至轻度游戏的小型设备。在这篇评论中&#xff0c;我们将了解 M2 Zero 的性能、功能和价值。 什么是 Banana Pi BPI-M2 Zero Banana Pi M2 Zero 是由深圳公…

MongoDB(Windows版)安装

首先需要下载 官网&#xff1a;MongoDB: The Developer Data Platform | MongoDB 安装过程 需要安装的版本 第一步&#xff1a;安装时&#xff0c;Custom是指可以自定义安装路径&#xff0c;然后傻瓜式安装即可&#xff08;注意&#xff1a;先不要安装图形化工具&#xff0…

2023-06-17 LeetCode每日一题(分割圆的最少切割次数)

2023-06-17每日一题 一、题目编号 2481. 分割圆的最少切割次数二、题目链接 点击跳转到题目位置 三、题目描述 圆内一个 有效切割 &#xff0c;符合以下二者之一&#xff1a; 该切割是两个端点在圆上的线段&#xff0c;且该线段经过圆心。该切割是一端在圆心另一端在圆上…