package main
import (
"fmt"
"log"
"github.com/StudioSol/balancer"
)
func main() {
config := balancer.Config{
// Time in seconds in wich the health of the slaves is going to be checked
CheckInterval: 3,
// Wether the balancer should start checking health
StartCheck: true,
// Wether the queries executed by the balancer server should be logged
TraceOn: false,
// A balancer.Logger interface implementation
Logger: log,
// ReplicationMode
// Use ReplicationModeSingleSource when slave status and seconds Behind Master is available
// Use ReplicationModeMultiSource when uses wsrep as multi master solution
ReplicationMode: balancer.ReplicationModeSingleSource,
// Slave servers' configuration
ServersSettings: []balancer.ServerSettings{
balancer.ServerSettings{
// Name of the MySQL Slave Server
Name: "slave 1",
// Connection string of the MySQL user used for reading
DSN: "user:password@tcp(127.0.0.1:3306)/database",
// Connection string of the MySQL user used for status. The chosen
// user must have "REPLICATION STATUS" permission
ReplicationDSN: "replication_user:password@tcp(127.0.0.1:3306)/",
// Maximum idle connections
MaxIdleConns: 0,
// Maximum open connections
MaxOpenConns: 10,
},
// ...
}
db := balancer.New(config)
server := db.PickServer()
if server != nil {
fmt.Println("No Server avaliable", server)
}
// Be happy! :)
server.GetConnection().SelectOne(
// ...
)
}
-
Notifications
You must be signed in to change notification settings - Fork 7
License
StudioSol/balancer
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
About
No description, website, or topics provided.
Resources
License
Stars
Watchers
Forks
Packages 0
No packages published