repository.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package repository
  2. import (
  3. "city_chips/pkg/log"
  4. "context"
  5. "fmt"
  6. "github.com/redis/go-redis/v9"
  7. "github.com/spf13/viper"
  8. "gorm.io/driver/mysql"
  9. "gorm.io/gorm"
  10. "gorm.io/gorm/logger"
  11. "runtime"
  12. "time"
  13. )
  14. type Repository struct {
  15. db *gorm.DB
  16. rdb *redis.Client
  17. logger *log.Logger
  18. }
  19. func NewRepository(logger *log.Logger, db *gorm.DB, rdb *redis.Client) *Repository {
  20. return &Repository{
  21. db: db,
  22. rdb: rdb,
  23. logger: logger,
  24. }
  25. }
  26. func NewDb(conf *viper.Viper, l *log.Logger) *gorm.DB {
  27. // TODO: init db
  28. sysType := runtime.GOOS
  29. config := gorm.Config{}
  30. if sysType == "windows" {
  31. config.Logger = logger.Default.LogMode(logger.Info)
  32. config.DisableForeignKeyConstraintWhenMigrating = true
  33. } else if sysType == "linux" {
  34. config.DisableForeignKeyConstraintWhenMigrating = true
  35. }
  36. db, err := gorm.Open(mysql.Open(conf.GetString("data.mysql.user")), &config)
  37. sqlDB, err := db.DB()
  38. // 设置最大连接数
  39. sqlDB.SetMaxOpenConns(20) // 设置最大打开连接数
  40. // 设置空闲连接数
  41. sqlDB.SetMaxIdleConns(200) // 设置最大空闲连接数
  42. // 设置连接的最大存活时间
  43. sqlDB.SetConnMaxLifetime(time.Hour) // 设置连接的最大存活时间为1小时
  44. if err != nil {
  45. panic(err)
  46. }
  47. return db
  48. }
  49. func NewRedis(conf *viper.Viper) *redis.Client {
  50. rdb := redis.NewClient(&redis.Options{
  51. Addr: conf.GetString("data.redis.addr"),
  52. Password: conf.GetString("data.redis.password"),
  53. DB: conf.GetInt("data.redis.db"),
  54. })
  55. ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
  56. defer cancel()
  57. _, err := rdb.Ping(ctx).Result()
  58. if err != nil {
  59. panic(fmt.Sprintf("redis error: %s", err.Error()))
  60. }
  61. return rdb
  62. }