1 Star 0 Fork 0

eden-framework / eden-framework

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
postgres.go 2.69 KB
一键复制 编辑 原始数据 按行查看 历史
文兄 提交于 2023-05-12 23:03 . feat. 支持nacos
package confpostgres
import (
"context"
"fmt"
"gitee.com/eden-framework/envconfig"
"gitee.com/eden-framework/sqlx"
"gitee.com/eden-framework/sqlx/postgresqlconnector"
"time"
)
type Postgres struct {
Host string
SlaveHost string
Port int
User string
Password envconfig.Password
Extra string
Extensions []string
PoolSize int
ConnMaxLifetime envconfig.Duration
Database *sqlx.Database `ignored:"true"`
*sqlx.DB `ignored:"true"`
slaveDB *sqlx.DB `ignored:"true"`
}
func (m *Postgres) LivenessCheck() map[string]string {
s := map[string]string{}
_, err := m.DB.ExecContext(context.Background(), "SELECT 1")
if err != nil {
s[m.Host] = err.Error()
} else {
s[m.Host] = "ok"
}
if m.slaveDB != nil {
_, err := m.slaveDB.ExecContext(context.Background(), "SELECT 1")
if err != nil {
s[m.SlaveHost] = err.Error()
} else {
s[m.SlaveHost] = "ok"
}
}
return s
}
func (m *Postgres) SetDefaults() {
if m.Host == "" {
m.Host = "127.0.0.1"
}
if m.Port == 0 {
m.Port = 5432
}
if m.PoolSize == 0 {
m.PoolSize = 10
}
if m.ConnMaxLifetime == 0 {
m.ConnMaxLifetime = envconfig.Duration(1 * time.Hour)
}
if m.Extra == "" {
m.Extra = "sslmode=disable"
}
}
func (m *Postgres) url(host string) string {
password := m.Password
if password != "" {
password = ":" + password
}
return fmt.Sprintf("postgres://%s%s@%s:%d", m.User, password, host, m.Port)
}
func (m *Postgres) conn(host string) (*sqlx.DB, error) {
db := m.Database.OpenDB(
&postgresqlconnector.PostgreSQLConnector{
Host: m.url(host),
Extra: m.Extra,
Extensions: m.Extensions,
},
)
db.SetMaxOpenConns(m.PoolSize)
db.SetMaxIdleConns(m.PoolSize / 2)
db.SetConnMaxLifetime(time.Duration(m.ConnMaxLifetime))
_, err := db.ExecContext(context.Background(), "SELECT 1")
if err != nil {
return nil, err
}
return db, nil
}
func (m *Postgres) UseSlave() sqlx.DBExecutor {
if m.slaveDB != nil {
return m.slaveDB
}
return m.DB
}
func (m *Postgres) Init() {
r := Retry{Repeats: 5, Interval: envconfig.Duration(1 * time.Second)}
err := r.Do(
func() error {
db, err := m.conn(m.Host)
if err != nil {
return err
}
m.DB = db
return nil
},
)
if err != nil {
panic(err)
}
if m.SlaveHost != "" {
err := r.Do(
func() error {
db, err := m.conn(m.Host)
if err != nil {
return err
}
m.slaveDB = db
return nil
},
)
if err != nil {
panic(err)
}
}
}
func SwitchSlave(executor sqlx.DBExecutor) sqlx.DBExecutor {
if canSlave, ok := executor.(CanSlave); !ok {
return canSlave.UseSlave()
}
return executor
}
type CanSlave interface {
UseSlave() sqlx.DBExecutor
}
1
https://gitee.com/eden-framework/eden-framework.git
git@gitee.com:eden-framework/eden-framework.git
eden-framework
eden-framework
eden-framework
v1.4.7

搜索帮助

53164aa7 5694891 3bd8fe86 5694891