sqldb

package
v1.4.0-rc1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 19, 2022 License: Apache-2.0 Imports: 18 Imported by: 0

README

sqldb

sqldb 主要解决以下问题:

  • 加载数据库配置
  • 记录 sql 执行日志
  • 上报 opentracing 追踪数据
  • 汇总 prometheus 监控指标

核心思想是用github.com/ngrok/sqlmw把现有的database/sql驱动包起来, 拦截所有数据库操作进行观察。

配置

框架默认支持 sqlite 和 mysql。

每个数据库的配置需要指定一个名字,并添加SQLDB_DSN_前缀。

# sqlite 配置示例
SQLDB_DSN_lite1 = "file:///tmp/foo.db"
# mysql 配置示例
SQLDB_DSN_mysql1 = "username:password@protocol(address)/dbname?param=value"

不同的驱动需要不同的配置内容:

使用

框架通过sqldb.Get(name)函数获取数据库实例,入参是配置名(去掉前缀), 返回的是*sqlx.DB对象。

框架会根据配置内容自动识别数据库驱动。

ctx, db := sqldb.Get(ctx, "name")
db.ExecContext(ctx, "delete from ...")

现有问题

受限于 database/sql 驱动的设计,我们无法在提交或者回滚事务的时候确定总耗时。

目前只能监控 begin/commit/rollback 单个查询耗时,而非事务总耗时。

添加新驱动

如果想添加 sqlite 和 mysql 之外的数据库驱动(比如 postgres),需要做两件事。

首先是注册驱动,此部分代码需要添加到 observer.go 的init()函数:

sql.Register("db-pg", sqlmw.Driver(pg.Driver{}, observer{}))

第一个参数是驱动的名字,可以随便取,但不能跟已经注册的冲突。建议添加pb-前缀。

然后就是根据配置内容指定驱动名字,这部分代码需要添加到 sqldb.go 的Get()函数:

dsn := conf.Get("SQLDB_DSN_" + name)
var driver string
if strings.HasPrefix(dsn, "file://") {
	driver = "db-sqlite"
} else if strings.HasPrefix(dsn, "postgres://") {
	driver = "db-pq" // 这里需要跟注册的名字保持一致
} else {
	driver = "db-mysql"
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Get

func Get(ctx context.Context, name string) (context.Context, *sqlx.DB)

Get 获取数据库实例

ctx, db := sqldb.Get(ctx, "foo") db.ExecContext(ctx, "select ...")

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL