package db import ( "Open_IM/pkg/common/config" "github.com/garyburd/redigo/redis" "gopkg.in/mgo.v2" "time" ) var DB DataBases type DataBases struct { MysqlDB mysqlDB mgoSession *mgo.Session redisPool *redis.Pool } func key(dbAddress, dbName string) string { return dbAddress + "_" + dbName } func init() { //mysql init initMysqlDB() // mongo init mgoDailInfo := &mgo.DialInfo{ Addrs: config.Config.Mongo.DBAddress, Direct: config.Config.Mongo.DBDirect, Timeout: time.Second * time.Duration(config.Config.Mongo.DBTimeout), Database: config.Config.Mongo.DBDatabase, Source: config.Config.Mongo.DBSource, Username: config.Config.Mongo.DBUserName, Password: config.Config.Mongo.DBPassword, PoolLimit: config.Config.Mongo.DBMaxPoolSize, } mgoSession, err := mgo.DialWithInfo(mgoDailInfo) if err != nil { panic(err) } DB.mgoSession = mgoSession DB.mgoSession.SetMode(mgo.Monotonic, true) // redis pool init DB.redisPool = &redis.Pool{ MaxIdle: config.Config.Redis.DBMaxIdle, MaxActive: config.Config.Redis.DBMaxActive, IdleTimeout: time.Duration(config.Config.Redis.DBIdleTimeout) * time.Second, Dial: func() (redis.Conn, error) { return redis.Dial( "tcp", config.Config.Redis.DBAddress, redis.DialReadTimeout(time.Duration(1000)*time.Millisecond), redis.DialWriteTimeout(time.Duration(1000)*time.Millisecond), redis.DialConnectTimeout(time.Duration(1000)*time.Millisecond), redis.DialDatabase(0), redis.DialPassword(config.Config.Redis.DBPassWord), ) }, } }