”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 Golang 和 GoFr 更改运行时日志级别

使用 Golang 和 GoFr 更改运行时日志级别

发布于2024-07-30
浏览:695

在本文中,我将分享如何在不重新启动应用程序的情况下更改应用程序的日志级别。

介绍

日志级别通常被认为是按重要性排序:在开发中打开“不重要”级别(通知、调试等),但在开发中仅启用“最重要”级别(警告、错误等)。生产环境,CPU 时间和磁盘空间等资源非常宝贵。

但是,如果您的应用程序运行在 ERROR 级别并且您开始面临许多问题,但您无法从 ERROR 级别日志中找出答案,那么通过重新部署应用程序来更改日志级别将花费大量时间和资源。

此外,在生产中以 INFO 或 DEBUG 级别运行应用程序将生成大量日志,这些日志可能会压垮日志系统,导致 I/O 操作和资源消耗增加。

为了解决这些问题,GoFr - 终极 Golang 框架提供了一种安全的方法来更改日志级别,而无需重新启动应用程序。

更改日志级别

要更改日志级别,任何 GoFr 应用程序都需要以下配置:

REMOTE_LOG_URL= (e.g., https://log-service.com/log-levels?id=1)

GoFr 默认每 15 秒获取一次提供的端点以获取最新的日志级别,可以通过添加以下配置来增加或减少此间隔。

REMOTE_LOG_FETCH_INTERVAL= (default: 15)

日志级别服务

GoFr 要求 URL 的响应采用以下格式,并带有两个必填字段:

{
    "data": {
       "serviceName": "test-service",
       "logLevel": "DEBUG"
    }
}

让我们创建日志级别服务,它将为我们的应用程序提供日志级别。

我将使用 GoFr 创建服务,请参阅文档以了解更多信息。

我们将使用 MySQL 作为数据库,要添加 MySQL,请在 configs 目录中的 .env 文件中添加以下配置。

DB_HOST=localhost
DB_USER=root
DB_PASSWORD=password
DB_NAME=log-level
DB_PORT=2001
DB_DIALECT=mysql

要运行 MySQL docker 容器,请运行以下命令

docker run --name gofr-logger -e MYSQL_ROOT_PASSWORD=password -e MYSQL_DATABASE=log-level -p 2001:3306 -d mysql:8.0.30

让我们添加带有迁移的 main.go 文件来创建表,我们将使用 AddRESTHandler 功能来注册路由。

main.go

package main

import (
 "gofr.dev/pkg/gofr"
 "gofr.dev/pkg/gofr/migration"
)

const createTable = `CREATE TABLE level (
    id INT PRIMARY KEY,
    service_name VARCHAR(255) NOT NULL,
    log_level VARCHAR(50) NOT NULL
);
`

func createTableLevel() migration.Migrate {
 return migration.Migrate{
  UP: func(d migration.Datasource) error {
   _, err := d.SQL.Exec(createTable)
   if err != nil {
    return err
   }

   return nil
  },
 }
}

type Level struct {
 ID          int    `json:"id"`
 ServiceName string `json:"serviceName"`
 LogLevel    string `json:"logLevel"`
}

func (u *Level) RestPath() string {
 return "level"
}

func main() {
 app := gofr.New()

 app.Migrate(map[int64]migration.Migrate{1: createTableLevel()})

 err := app.AddRESTHandlers(&Level{})
 if err != nil {
  app.Logger().Fatalf("Failed to register routes for level struct: %v", err)
 }

 app.Run()
}

运行日志服务后我们会看到如下日志:

LOGS FOR LOG-LEVEL CHANGE SERVICE STARTUP

我们已注册所有 REST 路线。

要创建服务,请发送以下请求:

curl --location 'localhost:8000/level' \
--header 'Content-Type: application/json' \
--data '{
    "id":1,
    "logLevel":"INFO",
    "serviceName":"gofr-app"
}'

要更新日志级别,请发送以下请求:

curl --location --request PUT 'localhost:8000/level/1' \
--header 'Content-Type: application/json' \
--data '{
    "id":1,
    "logLevel":"DEBUG",
    "serviceName":"gofr-app"
}'

要获取日志级别,请发送以下请求:

curl --location 'localhost:8000/level/1'

相同的 URL 将用于我们的应用程序的配置中,其日志级别必须远程更改。

结论

通过使用 GoFr 远程日志级别更改功能,您将获得以下好处:

  • 轻松调整:
    随时修改日志级别,无需重新启动应用程序。这在故障排除期间特别有用。

  • 增强可见性:
    轻松切换到更详细的日志级别(例如 DEBUG)以更深入地了解特定问题,然后切换回不太详细的级别(例如 INFO)以进行常规操作。

  • 改进的性能:
    生成大量日志会使日志系统不堪重负,导致 I/O 操作和资源消耗增加,更改为警告或错误级别可减少日志数量,增强性能,并降低云成本

通过给予 ⭐star 支持 GoFr: https://github.com/gofr-dev/gofr

此外,您可以访问免费公共端点来导出和查看应用程序的跟踪@tracer.gofr.dev。 
要启用它,请在您的 .env 文件中添加以下配置

TRACE_EXPORTER=gofr

其他福利:
如果您在开发或撰写文章方面为 GOFR 做出了贡献。您可以通过填写 GitHub 上的表格来获得免费的 赠品(T 恤、贴纸) 自述文件(位于底部)。

版本声明 本文转载于:https://dev.to/aryanmehrotra/remote-runtime-log-level-change-using-golang-gofr-54d8?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-07-12
  • 如何在JavaScript对象中动态设置键?
    如何在JavaScript对象中动态设置键?
    在尝试为JavaScript对象创建动态键时,如何使用此Syntax jsObj['key' i] = 'example' 1;不工作。正确的方法采用方括号: jsobj ['key''i] ='example'1; 在JavaScript中,数组是一...
    编程 发布于2025-07-12
  • PHP SimpleXML解析带命名空间冒号的XML方法
    PHP SimpleXML解析带命名空间冒号的XML方法
    在php 很少,请使用该限制很大,很少有很高。例如:这种技术可确保可以通过遍历XML树和使用儿童()方法()方法的XML树和切换名称空间来访问名称空间内的元素。
    编程 发布于2025-07-12
  • Java中假唤醒真的会发生吗?
    Java中假唤醒真的会发生吗?
    在Java中的浪费唤醒:真实性或神话?在Java同步中伪装唤醒的概念已经是讨论的主题。尽管存在这种行为的潜力,但问题仍然存在:它们实际上是在实践中发生的吗? Linux的唤醒机制根据Wikipedia关于伪造唤醒的文章,linux实现了pthread_cond_wait()功能的Linux实现,利用...
    编程 发布于2025-07-12
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-07-12
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-07-12
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    删除匿名事件侦听器将匿名事件侦听器添加到元素中会提供灵活性和简单性,但是当要删除它们时,可以构成挑战,而无需替换元素本身就可以替换一个问题。 element? element.addeventlistener(event,function(){/在这里工作/},false); 要解决此问题,请考虑...
    编程 发布于2025-07-12
  • 如何使用Python有效地以相反顺序读取大型文件?
    如何使用Python有效地以相反顺序读取大型文件?
    在python 中,如果您使用一个大文件,并且需要从最后一行读取其内容,则在第一行到第一行,Python的内置功能可能不合适。这是解决此任务的有效解决方案:反向行读取器生成器 == ord('\ n'): 缓冲区=缓冲区[:-1] ...
    编程 发布于2025-07-12
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-07-12
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, AttributeError: SomeClass...
    编程 发布于2025-07-12
  • 同实例无需转储复制MySQL数据库方法
    同实例无需转储复制MySQL数据库方法
    在同一实例上复制一个MySQL数据库而无需转储在同一mySQL实例上复制数据库,而无需创建InterMediate sqql script。以下方法为传统的转储和IMPORT过程提供了更简单的替代方法。 直接管道数据 MySQL手动概述了一种允许将mysqldump直接输出到MySQL clie...
    编程 发布于2025-07-12
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-07-12
  • 为什么HTML无法打印页码及解决方案
    为什么HTML无法打印页码及解决方案
    无法在html页面上打印页码? @page规则在@Media内部和外部都无济于事。 HTML:Customization:@page { margin: 10%; @top-center { font-family: sans-serif; font-weight: bo...
    编程 发布于2025-07-12
  • 如何限制动态大小的父元素中元素的滚动范围?
    如何限制动态大小的父元素中元素的滚动范围?
    在交互式接口中实现垂直滚动元素的CSS高度限制问题:考虑一个布局,其中我们具有与用户垂直滚动一起移动的可滚动地图div,同时与固定的固定sidebar保持一致。但是,地图的滚动无限期扩展,超过了视口的高度,阻止用户访问页面页脚。$("#map").css({ marginT...
    编程 发布于2025-07-12
  • 哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    编程 发布于2025-07-12

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3