-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmysql_connection_manager.go
125 lines (101 loc) · 2.56 KB
/
mysql_connection_manager.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package mysql_storage
import (
"context"
"database/sql"
"fmt"
"github.com/storage-lock/go-storage"
"sync"
)
// MysqlConnectionManager 创建一个MySQL的连接管理器
type MysqlConnectionManager struct {
// 主机的名字
Host string
// 主机的端口
Port uint
// 用户名
User string
// 密码
Passwd string
DatabaseName string
DSN string
// 初始化好的数据库实例
db *sql.DB
err error
once sync.Once
}
var _ storage.ConnectionManager[*sql.DB] = &MysqlConnectionManager{}
// NewMysqlConnectionManagerFromDsn 从DSN创建MySQL连接管理器
func NewMysqlConnectionManagerFromDsn(dsn string) *MysqlConnectionManager {
return &MysqlConnectionManager{
DSN: dsn,
}
}
func NewMysqlConnectionManagerFromSqlDb(db *sql.DB) *MysqlConnectionManager {
return &MysqlConnectionManager{
db: db,
}
}
// NewMysqlConnectionManager 从连接属性创建数据库连接
func NewMysqlConnectionManager(host string, port uint, user, passwd, database string) *MysqlConnectionManager {
return &MysqlConnectionManager{
Host: host,
Port: port,
User: user,
Passwd: passwd,
DatabaseName: database,
}
}
func (x *MysqlConnectionManager) SetHost(host string) *MysqlConnectionManager {
x.Host = host
return x
}
func (x *MysqlConnectionManager) SetPort(port uint) *MysqlConnectionManager {
x.Port = port
return x
}
func (x *MysqlConnectionManager) SetUser(user string) *MysqlConnectionManager {
x.User = user
return x
}
func (x *MysqlConnectionManager) SetPasswd(passwd string) *MysqlConnectionManager {
x.Passwd = passwd
return x
}
func (x *MysqlConnectionManager) SetDatabaseName(databaseName string) *MysqlConnectionManager {
x.DatabaseName = databaseName
return x
}
const MysqlConnectionManagerName = "mysql-connection-manager"
func (x *MysqlConnectionManager) Name() string {
return MysqlConnectionManagerName
}
// Take 获取到数据库的连接
func (x *MysqlConnectionManager) Take(ctx context.Context) (*sql.DB, error) {
x.once.Do(func() {
if x.db != nil || x.err != nil {
return
}
db, err := sql.Open("mysql", x.GetDSN())
if err != nil {
x.err = err
return
}
x.db = db
})
return x.db, x.err
}
func (x *MysqlConnectionManager) GetDSN() string {
if x.DSN != "" {
return x.DSN
}
return fmt.Sprintf("%s:%s@tcp(%s:%d)/%s", x.User, x.Passwd, x.Host, x.Port, x.DatabaseName)
}
func (x *MysqlConnectionManager) Return(ctx context.Context, db *sql.DB) error {
return nil
}
func (x *MysqlConnectionManager) Shutdown(ctx context.Context) error {
if x.db != nil {
return x.db.Close()
}
return nil
}