xorm/engine_group.go

185 lines
4.1 KiB
Go
Raw Normal View History

2017-09-26 03:29:41 +00:00
// Copyright 2017 The Xorm Authors. All rights reserved.
2017-09-25 12:32:49 +00:00
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package xorm
import (
2017-09-25 13:54:40 +00:00
"strings"
2017-09-25 12:32:49 +00:00
"time"
"github.com/go-xorm/core"
)
2017-09-26 01:45:51 +00:00
type EngineGroup struct {
2017-09-26 04:50:49 +00:00
*Engine
slaves []*Engine
policy GroupPolicy
2017-09-26 01:45:51 +00:00
}
2017-09-26 03:29:41 +00:00
func NewGroup(args1 interface{}, args2 interface{}, policies ...GroupPolicy) (*EngineGroup, error) {
2017-09-26 04:50:49 +00:00
var eg EngineGroup
2017-09-26 03:26:06 +00:00
if len(policies) > 0 {
2017-09-26 04:50:49 +00:00
eg.policy = policies[0]
2017-09-26 03:26:06 +00:00
} else {
2017-09-26 04:50:49 +00:00
eg.policy = NewRandomPolicy()
2017-09-26 03:26:06 +00:00
}
2017-09-26 01:45:51 +00:00
driverName, ok1 := args1.(string)
dataSourceNames, ok2 := args2.(string)
if ok1 && ok2 {
2017-09-26 04:50:49 +00:00
conns := strings.Split(dataSourceNames, ";")
engines := make([]*Engine, len(conns))
for i, conn := range conns {
engine, err := NewEngine(driverName, conn)
if err != nil {
return nil, err
}
engine.engineGroup = &eg
engines[i] = engine
}
2017-09-26 01:45:51 +00:00
2017-09-26 04:50:49 +00:00
eg.Engine = engines[0]
eg.slaves = engines[1:]
return &eg, nil
2017-09-26 01:45:51 +00:00
}
2017-09-25 12:32:49 +00:00
2017-09-26 04:50:49 +00:00
master, ok3 := args1.(*Engine)
slaves, ok4 := args2.([]*Engine)
if ok3 && ok4 {
master.engineGroup = &eg
for i := 0; i < len(slaves); i++ {
slaves[i].engineGroup = &eg
2017-09-25 13:54:40 +00:00
}
2017-09-26 04:50:49 +00:00
return &eg, nil
2017-09-25 13:54:40 +00:00
}
2017-09-26 04:50:49 +00:00
return nil, ErrParamsType
2017-09-26 01:45:51 +00:00
}
2017-09-26 03:29:41 +00:00
func (eg *EngineGroup) SetPolicy(policy GroupPolicy) *EngineGroup {
2017-09-26 01:45:51 +00:00
eg.policy = policy
return eg
}
func (eg *EngineGroup) Master() *Engine {
2017-09-26 04:50:49 +00:00
return eg.Engine
2017-09-25 12:32:49 +00:00
}
// Slave returns one of the physical databases which is a slave
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) Slave() *Engine {
2017-09-26 04:50:49 +00:00
switch len(eg.slaves) {
case 0:
return eg.Engine
case 1:
return eg.slaves[0]
2017-09-26 01:45:51 +00:00
}
if eg.s_count == 1 {
return eg.slaves[0]
}
2017-09-26 02:22:13 +00:00
return eg.policy.Slave(eg)
2017-09-25 12:32:49 +00:00
}
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) Slaves() []*Engine {
return eg.slaves
2017-09-25 12:32:49 +00:00
}
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) GetSlave(i int) *Engine {
return eg.slaves[i]
2017-09-25 13:54:40 +00:00
}
2017-09-25 12:32:49 +00:00
// ShowSQL show SQL statement or not on logger if log level is great than INFO
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) ShowSQL(show ...bool) {
2017-09-26 04:50:49 +00:00
eg.Engine.ShowSQL(show...)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].ShowSQL(show...)
2017-09-25 12:32:49 +00:00
}
}
// ShowExecTime show SQL statement and execute time or not on logger if log level is great than INFO
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) ShowExecTime(show ...bool) {
2017-09-26 04:50:49 +00:00
eg.Engine.ShowExecTime(show...)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].ShowExecTime(show...)
2017-09-25 12:32:49 +00:00
}
}
// SetMapper set the name mapping rules
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetMapper(mapper core.IMapper) {
2017-09-26 04:50:49 +00:00
eg.Engine.SetTableMapper(mapper)
eg.Engine.SetColumnMapper(mapper)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].SetTableMapper(mapper)
eg.slaves[i].SetColumnMapper(mapper)
2017-09-25 12:32:49 +00:00
}
}
// SetTableMapper set the table name mapping rule
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetTableMapper(mapper core.IMapper) {
2017-09-26 04:50:49 +00:00
eg.Engine.TableMapper = mapper
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].TableMapper = mapper
2017-09-25 12:32:49 +00:00
}
}
// SetColumnMapper set the column name mapping rule
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetColumnMapper(mapper core.IMapper) {
2017-09-26 04:50:49 +00:00
eg.Engine.ColumnMapper = mapper
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].ColumnMapper = mapper
2017-09-25 12:32:49 +00:00
}
}
// SetMaxOpenConns is only available for go 1.2+
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetMaxOpenConns(conns int) {
2017-09-26 04:50:49 +00:00
eg.Engine.db.SetMaxOpenConns(conns)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].db.SetMaxOpenConns(conns)
2017-09-25 12:32:49 +00:00
}
}
// SetMaxIdleConns set the max idle connections on pool, default is 2
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetMaxIdleConns(conns int) {
2017-09-26 04:50:49 +00:00
eg.Engine.db.SetMaxIdleConns(conns)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].db.SetMaxIdleConns(conns)
2017-09-25 12:32:49 +00:00
}
}
// Close the engine
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) Close() error {
2017-09-26 04:50:49 +00:00
err := eg.Engine.db.Close()
2017-09-26 01:45:51 +00:00
if err != nil {
return err
}
for i, _ := range eg.slaves {
err := eg.slaves[i].db.Close()
2017-09-25 12:32:49 +00:00
if err != nil {
return err
}
}
return nil
}
// Ping tests if database is alive
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) Ping() error {
2017-09-26 04:50:49 +00:00
if err := eg.Engine.Ping(); err != nil {
return err
}
for _, slave := range eg.slaves {
if err := slave.Ping(); err != nil {
return err
}
}
return nil
2017-09-25 12:32:49 +00:00
}
// SetConnMaxLifetime sets the maximum amount of time a connection may be reused.
2017-09-26 01:45:51 +00:00
func (eg *EngineGroup) SetConnMaxLifetime(d time.Duration) {
2017-09-26 04:50:49 +00:00
eg.Engine.db.SetConnMaxLifetime(d)
2017-09-26 01:45:51 +00:00
for i, _ := range eg.slaves {
eg.slaves[i].db.SetConnMaxLifetime(d)
2017-09-25 12:32:49 +00:00
}
}