gozero项目接入elk的配置与实战

在 **GoZero** 项目中接入 **ELK(Elasticsearch、Logstash、Kibana)** 来进行日志管理,是一个非常强大的监控和分析方案。通过集成 ELK,你可以收集、存储、查询和可视化日志数据。

661ebdc93a8041dabc0c214a1100ee9e.png

在这里,我将介绍如何在 GoZero 项目中集成 ELK,特别是将 GoZero 的日志发送到 **Elasticsearch**,并在 **Kibana** 中进行可视化。我们会结合 **Logstash** 或 **Filebeat** 来进行日志的传输。081703c3df7b439fb07d7138f3e8e186.png

### 1. 安装和配置 ELK 堆栈

如果你还没有安装 ELK,可以通过以下步骤安装。

#### 1) 安装 Elasticsearch

从 [Elasticsearch 官网](https://www.elastic.co/downloads/elasticsearch) 下载并安装 Elasticsearch。安装完成后,可以通过以下命令启动 Elasticsearch:

```bash
# 启动 Elasticsearch(假设你已经安装了它)

./bin/elasticsearch


```

Elasticsearch 默认运行在 `http://localhost:9200`。

#### 2) 安装 Kibana

从 [Kibana 官网](https://www.elastic.co/downloads/kibana) 下载并安装 Kibana。安装完成后,可以通过以下命令启动 Kibana:

```bash
# 启动 Kibana(假设你已经安装了它)

./bin/kibana


```

Kibana 默认运行在 `http://localhost:5601`,可以通过浏览器访问 Kibana UI。

#### 3) 安装 Logstash 或 Filebeat(可选)

你可以选择使用 **Logstash** 或 **Filebeat** 来将日志从 GoZero 发送到 Elasticsearch。

##### 选择 1:使用 **Filebeat**

Filebeat 是一个轻量级的日志收集器,适合直接从文件中收集日志并发送到 Elasticsearch。

- 下载并安装 Filebeat:[Filebeat 官网](https://www.elastic.co/downloads/beats/filebeat)
- 配置 Filebeat(在 `filebeat.yml` 配置文件中):```yaml

filebeat.inputs:- type: logenabled: truepaths:- /path/to/gozero/logs/*.log  # 这里是 GoZero 日志的存储路径output.elasticsearch:hosts: ["http://localhost:9200"]


```

启动 Filebeat:

```bash

./filebeat -e


```

##### 选择 2:使用 **Logstash**

Logstash 是一个功能强大的日志处理工具,适合对日志进行更加复杂的处理(如过滤、转换等)。

- 下载并安装 Logstash:[Logstash 官网](https://www.elastic.co/downloads/logstash)
- 配置 Logstash(在 `logstash.conf` 配置文件中):```plaintext

input {file {path => "/path/to/gozero/logs/*.log"  # GoZero 日志路径start_position => "beginning"}
}filter {# 这里可以进行日志过滤和处理
}output {elasticsearch {hosts => ["http://localhost:9200"]index => "gozero-logs-%{+YYYY.MM.dd}"}
}


```

启动 Logstash:

```bash

./bin/logstash -f logstash.conf


```

### 2. 配置 GoZero 日志

GoZero 提供了灵活的日志配置,可以直接将日志输出到文件或日志服务器。你可以配置日志记录到本地文件,然后通过 **Filebeat** 或 **Logstash** 将日志发送到 Elasticsearch。

#### 配置 GoZero 日志

在 GoZero 中,你可以通过 `logx` 模块来管理日志。你需要在 GoZero 配置文件中设置日志输出到文件,然后确保文件的路径与 Filebeat 或 Logstash 配置匹配。```go

package mainimport ("github.com/tal-tech/go-zero/core/logx""github.com/tal-tech/go-zero/zrpc"
)func main() {// 设置日志配置logx.MustSetup(logx.LogConf{Path:     "./logs",  // 日志文件路径Level:    "info",    // 日志级别MaxSize:  100,       // 每个日志文件的最大大小(MB)MaxAge:   30,        // 保留日志的天数MaxBackups: 10,      // 保留的备份文件数量Compress: true,      // 是否启用日志压缩})// 启动 GoZero RPC 服务server := zrpc.MustNewServer(zrpc.RpcServerConf{ListenOn: ":8888",}, func(s *zrpc.Server) {// 启动后输出日志logx.Info("GoZero server started")})defer server.Stop()server.Start()
}


```

- `logx.LogConf` 中配置了日志的路径、日志级别等。日志会保存在 `./logs` 目录下。
- 可以根据需要调整 `Path`(日志文件路径)、`Level`(日志级别)等参数。

### 3. 配置 Elasticsearch 日志映射

为了更好地查询和展示日志,你可能需要定义一个适合 GoZero 日志的 Elasticsearch **映射(Mapping)**。通过自定义映射,可以指定字段类型、索引策略等。

以下是一个示例映射,可以在 Elasticsearch 中创建索引时使用:

```json

PUT /gozero-logs-2024.12.28
{"mappings": {"properties": {"timestamp": {"type": "date"},"level": {"type": "keyword"},"message": {"type": "text"},"method": {"type": "keyword"},"status": {"type": "keyword"}}}
}


```

### 4. 通过 Kibana 可视化日志

一旦日志被成功推送到 Elasticsearch,您可以使用 Kibana 来查询和可视化日志。

#### 1) 配置 Kibana 数据源

在 Kibana 中,打开 Web UI,选择 **Discover** 视图,并选择 GoZero 日志索引(例如 `gozero-logs-*`)。

#### 2) 创建仪表板

你可以在 Kibana 中创建仪表板,展示 GoZero 的日志数据。例如,展示按 `level` 分类的日志数量,或按 `method` 和 `status` 分类的日志分布。

#### 3) 设置告警(可选)

Kibana 和 Elasticsearch 支持设置告警,当日志中出现某些异常时,可以触发通知。

### 5. 实战总结

集成 GoZero 项目和 ELK 的步骤如下:8f559c868af6479992e6ffeedfb2ceb3.png

1. **安装并配置 ELK 堆栈**:安装 Elasticsearch、Kibana、Logstash 或 Filebeat。
2. **配置 GoZero 日志**:在 GoZero 中配置日志输出到文件,并设置日志格式。
3. **配置 Filebeat 或 Logstash**:选择一种工具(Filebeat 或 Logstash)将日志从 GoZero 发送到 Elasticsearch。
4. **查询和可视化日志**:在 Kibana 中创建仪表板,查看 GoZero 的日志数据,并设置告警等。

这种集成方式能够为你提供强大的日志监控和分析能力,帮助你及时发现应用中的问题,提高开发和运维效率。

 

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

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

相关文章

探索PIL库:Python图像处理的强大工具

文章一览 前言一、PIL图像处理库简介二、基本概念2.1颜色模型2.1.1 RGB 颜色模型2.1.2 CMY色彩空间 2.2 通道2.3 图像数据2.4 模式 三、用PIL做图像处理3.1 图像缩放、翻转等处理3.1.1 图像缩放处理3.1.2 图像旋转处理(1)PIL 提供的函数:(2&a…

微信V3支付报错 平台证书及平台证书序列号

1.平台证书及平台证书序列号设置错误报错: 错误1: Verify the response’s data with: timestamp1735184656, noncea5806b8cabc923299f8db1a174f3a4d0, signatureFZ5FgD/jtt4J99GKssKWKA/0buBSOAbWcu6H52l2UqqaJKvrsNxvodB569ZFz5G3fbassOQcSh5BFq6hvE…

【Python科研数据爬虫】基于国家标准查询平台和能源标准化信息平台的海上风电相关行业标准查询信息爬取及处理

基于国家标准查询平台和能源标准化信息平台的海上风电相关行业标准查询信息爬取及处理 1 背景2 标准检索平台2.1 能源标准化信息平台2.2 全国标准信息公共服务平台3 标准信息数据的爬取与处理3.1 能源标准化信息平台的信息爬取3.2 全国标准信息公共服务平台的信息爬取3.3 标准信…

AWS Certified AI Practitioner 自学考试心得

学习目标: 考取 AWS Certified AI Practitioner 那什么是 AWS Certified AI Practitioner 认证 是基础级的认证 比较简单 — 学习内容: 1. AWS网站自学网站 极客时间免费课程:http://gk.link/a/12sJL 配合极客时间课程的章节测试检验自…

Ngnix介绍、安装、实战及用法!!!

一、Nginx简介 1、Nginx概述 Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理服务器,特点是占有内存少,并发能力强,能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数 。 2、正向代理 正向代理:如果把局…

05.HTTPS的实现原理-HTTPS的握手流程(TLS1.2)

05.HTTPS的实现原理-HTTPS的握手流程(TLS1.2) 简介1. TLS握手过程概述2. TLS握手过程细化3. 主密钥(对称密钥)生成过程4. 密码规范变更 简介 主要讲述了混合加密流程完成后,客户端和服务器如何共同获得相同的对称密钥…

YOLO11全解析:从原理到实战,全流程体验下一代目标检测

前言 一、模型介绍 二、网络结构 1.主干网络(Backbone) 2.颈部网络(Neck) 3.头部网络(Head) 三、算法改进 1.增强的特征提取 2.优化的效率和速度 3.更高的准确性与更少的参数 4.环境适应性强 5.…

Jenkins 构建流水线

在 Linux 系统上安装 Jenkins 服务,以及配置自动化构建项目 前置准备环境:docker、docker-compose、jdk、maven 一、环境搭建 1. Jenkins 安装 (1)拉取镜像 # 安装镜像包,默认安装最新版本 docker pull jenkins/jen…

【Java】面试题 并发安全 (1)

文章目录 synchronized1. 基本概念与作用2. 使用方式3. 底层原理(基于monitor)4. 面试题回答要点5. 注意事项与进阶理解 Java中synchronized锁相关知识总结Java内存模型(JMM)CAS概述及重要性volatile关键字AQS简介 synchronized …

前端项目 npm报错解决记录

1.首先尝试解决思路 npm报错就切换yarn , yarn报错就先切换npm删除 node_modules 跟 package-lock.json文件重新下载依 2. 报错信息: Module build failed: Error: Missing binding D:\vue-element-admin\node_modules\node-sass\vendor\win32-x64-8…

深度学习中batch_size

Batch size调整和epoch/iteration的关系 训练数据集总共有1000个样本。若batch_size10,那么训练完全体样本集需要100次迭代,1次epoch。 训练样本10000条,batchsize设置为20,将所有的训练样本在同一个模型中训练5遍,则…

评分模型在路网通勤习惯分析中的应用——提出问题(1)

1、问题的由来、目标和意义 最近一段时间和公司其它业务部门讨论时,发现一个有趣的交通路网问题,车辆从S点行驶到V点共用时40分钟,这段时间内路网中的卡口摄像头识别到了车辆通过的信息。如下图所示: 设计师需要通过这些有限的路…

MS SQL Server 实战 排查多列之间的值是否重复

目录 需求 范例运行环境 数据样本设计 功能实现 上传EXCEL文件到数据库 SQL语句 小结 需求 在日常的应用中,排查列重复记录是经常遇到的一个问题,但某些需求下,需要我们排查一组列之间是否有重复值的情况。比如我们有一组题库数据&am…

抖去推碰一碰系统技术源码/open SDK转发技术开发

抖去推碰一碰系统技术源码/open SDK转发技术开发 碰一碰智能系统#碰碰卡系统#碰一碰系统#碰一碰系统技术源头开发 碰碰卡智能营销系统开发是一种集成了人工智能和NFC技术的工具,碰碰卡智能营销系统通过整合数据分析、客户关系管理、自动化营销活动、多渠道整合和个…

WEB攻防-通用漏洞-文件上传-js验证-MIME验证-user.ini-语言特征

目录 定义 1.前端验证 2.MIME验证 3.htaccess文件和.user. ini 4.对内容进行了过滤,做了内容检测 5.[ ]符号过滤 6.内容检测php [] {} ; 7.()也被过滤了 8.反引号也被过滤 9.文件头检测 定义 文件上传漏洞是指攻击者上传了一个可执行文件(如木马…

未来网络技术的新征程:5G、物联网与边缘计算(10/10)

一、5G 网络:引领未来通信新潮流 (一)5G 网络的特点 高速率:5G 依托良好技术架构,提供更高的网络速度,峰值要求不低于 20Gb/s,下载速度最高达 10Gbps。相比 4G 网络,5G 的基站速度…

SuperMap iClient3D for Cesium等高线标注

kele 前言 在三维地形分析中,等高线分析是一种非常重要的分析方法,它能直观的表达出地形的高低起伏特征,在三维系统中受到广泛应用。在SuperMap iClient3D for Cesium中,等高线分析是前端GPU分析,能够分析并渲染出等高…

从 x86 到 ARM64:CPU 架构的进化与未来

在计算机发展的历史长河中,x86、x64 和 ARM64 这三大主流 CPU 架构各自书写了辉煌的篇章。它们不仅代表了技术的进步,更承载着无数创新者的梦想与努力。 x86:从 16 位到 32 位的辉煌之路 诞生与崛起 1978 年,英特尔(…

红魔电竞PadPro平板解BL+ROOT权限-KernelSU+LSPosed框架支持

红魔Padpro设备目前官方未开放解锁BL,也阉割了很多解锁BL指令,造成大家都不能自主玩机。此规则从红魔8开始,就一直延续下来,后续的机型大概率也是一样的情况。好在依旧有开发者进行适配研究,目前红魔PadPro平板&#x…

TCP Analysis Flags 之 TCP Out-Of-Order

前言 默认情况下,Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态,并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时,会对每个 TCP 数据包进行一次分析,数据包按照它们在数据包列表中出现的顺序进行处理。可…