123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- package dao
- import (
- "context"
- "math/rand"
- "time"
- "go-common/app/service/main/spy/conf"
- "go-common/library/cache/memcache"
- "go-common/library/cache/redis"
- "go-common/library/database/sql"
- bm "go-common/library/net/http/blademaster"
- "go-common/library/queue/databus"
- )
- type Dao struct {
- c *conf.Config
-
- db *sql.DB
-
- mcUser *memcache.Pool
- mcUserExpire int32
-
- redis *redis.Pool
- expire int
- verifyExpire int
-
- httpClient *bm.Client
- auditInfoURI string
-
- dbScoreChange *databus.Databus
- r *rand.Rand
- }
- func New(c *conf.Config) (d *Dao) {
- d = &Dao{
- c: c,
-
- db: sql.NewMySQL(c.DB.Spy),
-
- mcUser: memcache.NewPool(c.Memcache.User),
- mcUserExpire: int32(time.Duration(c.Memcache.UserExpire) / time.Second),
-
- redis: redis.NewPool(c.Redis.Config),
- expire: int(time.Duration(c.Redis.Expire) / time.Second),
- verifyExpire: int(time.Duration(c.Redis.VerifyCdTimes) / time.Second),
-
- httpClient: bm.NewClient(c.HTTPClient),
- auditInfoURI: c.Account + _auditInfo,
-
- dbScoreChange: databus.New(c.DBScoreChange),
- r: rand.New(rand.NewSource(time.Now().Unix())),
- }
- if conf.Conf.Property.UserInfoShard <= 0 {
- panic("conf.Conf.Property.UserInfoShard <= 0")
- }
- if conf.Conf.Property.HistoryShard <= 0 {
- panic("conf.Conf.Property.HistoryShard <= 0")
- }
- return
- }
- func (d *Dao) Ping(c context.Context) (err error) {
- if err = d.pingMC(c); err != nil {
- return
- }
- if err = d.PingRedis(c); err != nil {
- return
- }
- return d.db.Ping(c)
- }
- func (d *Dao) Close() {
- if d.mcUser != nil {
- d.mcUser.Close()
- }
- if d.redis != nil {
- d.redis.Close()
- }
- if d.db != nil {
- d.db.Close()
- }
- }
|