当前位置: 首页 > news >正文

golang 集成sentry:PostgreSQL

本文介绍通过 pgx库集成sentry, pgx 特点是速度快,可以完全控制,并且支持所有 postgres 数据类型。

pgx地址: https://github.com/jackc/pgx

最简单的接入方式是自定义一个logger, 然后注入到pgx, 完整示例如下

package mainimport ("context""log""os""time""github.com/getsentry/sentry-go""github.com/jackc/pgx/v4""github.com/jackc/pgx/v4/log/logrusadapter""github.com/jackc/pgx/v4/pgxpool""github.com/sirupsen/logrus"
)// TracingLogger does two things at once, logging and tracing
type TracingLogger struct {logger *logrusadapter.Logger
}func NewTracingLogger(logger logrus.FieldLogger) *TracingLogger {return &TracingLogger{logger: logrusadapter.NewLogger(logger)}
}func (l *TracingLogger) Log(ctx context.Context, level pgx.LogLevel, msg string, data map[string]interface{}) {l.logger.Log(ctx, level, msg, data)span := sentry.StartSpan(ctx, "postgres "+msg)defer span.Finish()if data != nil {if span.Data == nil {span.Data = make(map[string]interface{})}for key, value := range data {value, ok := value.(string)if ok {span.Data[key] = value}}// since this method is called after a query is done,// we need to correct span start timeexecTime, ok := data["time"].(time.Duration)if ok {span.StartTime = time.Now().Add(-execTime)}}
}func main() {err := sentry.Init(sentry.ClientOptions{Debug:              true,Dsn:                "https://a5eac4fa3396cbfac8fb4baa6a9c03a3@o4504291071688704.ingest.sentry.io/4506715873804288",AttachStacktrace:   true,EnableTracing:      true,SampleRate:         1.0,TracesSampleRate:   1.0,ProfilesSampleRate: 1.0,})if err != nil {log.Fatalf("sentry.Init: %s", err)}defer sentry.Flush(2 * time.Second)config, err := pgxpool.ParseConfig(os.Getenv("DATABASE_URL"))if err != nil {log.Fatal(err)}logger := logrus.New()config.ConnConfig.Logger = NewTracingLogger(logger)conn, err := pgxpool.ConnectConfig(ctx, config)if err != nil {log.Fatal(err)}defer conn.Close()ctx := context.Background()tx := sentry.StartTransaction(ctx, "test_pgx")defer tx.Finish()ctx = tx.Context()err = conn.QueryRow(ctx, "SELECT 1").Scan()if err != nil {log.Fatal(err)}
}

参考:
https://anymindgroup.com/news/tech-blog/15724/

http://www.lryc.cn/news/297747.html

相关文章:

  • ubuntu20.04 安装mysql(8.x)
  • ChatGPT升级至GPT-4 Turbo:性能升级同时更为经济
  • Android 粒子喷泉动效
  • fast.ai 深度学习笔记(一)
  • 【机器学习】Ubuntu系统下CUDA驱动卸载及重装
  • 相机图像质量研究(8)常见问题总结:光学结构对成像的影响--工厂调焦
  • 【MySQL】数据库基础 -- 详解
  • 零基础学Python之整合MySQL
  • 股票均线的使用方法和实战技术,看涨看空的均线形态与案例教学
  • 服务器被黑,安装Linux RootKit木马
  • 【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
  • 3d渲染100农场如何使用?渲染100邀请码1a12
  • 【数据结构和算法】--- 基于c语言排序算法的实现(2)
  • ORACLE的 软 软 软 解析!
  • 【模板】k 短路 / [SDOI2010] 魔法猪学院
  • 【Make编译控制 08】CMake动静态库
  • 05 06 Verilog基础语法与应用讲解
  • css2复合选择器
  • 新版MQL语言程序设计:键盘快捷键交易的设计与实现
  • 数据结构之基数排序
  • 区间dp 笔记
  • MySQL-SQL优化
  • 详细了解ref和reactive.
  • 使用Linux docker方式快速安装Plik并结合内网穿透实现公网访问
  • Redis Centos7 安装到启动
  • 「数据结构」二叉搜索树1:实现BST
  • 可达鸭二月月赛——基础赛第六场(周五)题解,这次四个题的题解都在这一篇文章内,满满干货,含有位运算的详细用法介绍。
  • ELFK日志采 - QuickStart
  • 微信小程序的图片色彩分析,窃取网络图片的主色调
  • Leetcode 121 买卖股票的最佳时机