package dao import ( "context" "time" "bom_server/internal/model" "github.com/go-kratos/kratos/pkg/cache/memcache" "github.com/go-kratos/kratos/pkg/cache/redis" "github.com/go-kratos/kratos/pkg/conf/paladin" "github.com/go-kratos/kratos/pkg/database/sql" "github.com/go-kratos/kratos/pkg/log" xtime "github.com/go-kratos/kratos/pkg/time" ) // Dao dao interface type Dao interface { Close() Ping(ctx context.Context) (err error) GetUserInfoByUserId(ctx context.Context,user_id int64) (r *model.Users,err error) } // dao dao. type dao struct { db *sql.DB redis *redis.Pool redisExpire int32 mc *memcache.Memcache mcExpire int32 } func checkErr(err error) { if err != nil { panic(err) } } // New new a dao and return. func New() (Dao) { var ( dc struct { Crm *sql.Config } rc struct { Demo *redis.Config DemoExpire xtime.Duration } mc struct { Demo *memcache.Config DemoExpire xtime.Duration } ) checkErr(paladin.Get("mysql.toml").UnmarshalTOML(&dc)) checkErr(paladin.Get("redis.toml").UnmarshalTOML(&rc)) checkErr(paladin.Get("memcache.toml").UnmarshalTOML(&mc)) return &dao{ // mysql db: sql.NewMySQL(dc.Crm), // redis redis: redis.NewPool(rc.Demo), redisExpire: int32(time.Duration(rc.DemoExpire) / time.Second), // memcache mc: memcache.New(mc.Demo), mcExpire: int32(time.Duration(mc.DemoExpire) / time.Second), } } // Close close the resource. func (d *dao) Close() { d.mc.Close() d.redis.Close() d.db.Close() } // Ping ping the resource. func (d *dao) Ping(ctx context.Context) (err error) { if err = d.pingMC(ctx); err != nil { return } if err = d.pingRedis(ctx); err != nil { return } return d.db.Ping(ctx) } func (d *dao) pingMC(ctx context.Context) (err error) { if err = d.mc.Set(ctx, &memcache.Item{Key: "ping", Value: []byte("pong"), Expiration: 0}); err != nil { log.Error("conn.Set(PING) error(%v)", err) } return } func (d *dao) pingRedis(ctx context.Context) (err error) { conn := d.redis.Get(ctx) defer conn.Close() if _, err = conn.Do("SET", "ping", "pong"); err != nil { log.Error("conn.Set(PING) error(%v)", err) } return }