message.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. // Code generated by goctl. DO NOT EDIT!
  2. // Source: message.proto
  3. package main
  4. import (
  5. "app.yhyue.com/moapp/MessageCenter/entity"
  6. "app.yhyue.com/moapp/MessageCenter/rpc/internal/config"
  7. "app.yhyue.com/moapp/MessageCenter/rpc/internal/server"
  8. "app.yhyue.com/moapp/MessageCenter/rpc/internal/svc"
  9. "app.yhyue.com/moapp/MessageCenter/rpc/type/message"
  10. m "app.yhyue.com/moapp/jybase/mongodb"
  11. "app.yhyue.com/moapp/jybase/mysql"
  12. "app.yhyue.com/moapp/jybase/redis"
  13. "flag"
  14. "fmt"
  15. "github.com/zeromicro/go-zero/core/conf"
  16. "github.com/zeromicro/go-zero/core/logx"
  17. "github.com/zeromicro/go-zero/zrpc"
  18. clientv3 "go.etcd.io/etcd/client/v3"
  19. "google.golang.org/grpc"
  20. "log"
  21. )
  22. var configFile = flag.String("f", "etc/message.yaml", "the config file")
  23. var logFile = flag.String("lf", "etc/logs.yaml", "the logs file")
  24. var logc entity.Logc
  25. var EtcdCli *clientv3.Client
  26. var Mysql *mysql.Mysql
  27. var c config.Config
  28. func main() {
  29. flag.Parse()
  30. conf.MustLoad(*configFile, &c)
  31. ctx := svc.NewServiceContext(c)
  32. srv := server.NewMessageServer(ctx)
  33. s := zrpc.MustNewServer(c.RpcServerConf, func(grpcServer *grpc.Server) {
  34. message.RegisterMessageServer(grpcServer, srv)
  35. })
  36. defer s.Stop()
  37. fmt.Printf("Starting rpc server at %s...\n", c.ListenOn)
  38. s.Start()
  39. }
  40. // 创建orm引擎
  41. func init() {
  42. conf.MustLoad(*configFile, &config.ConfigJson)
  43. log.Println("开始初始化数据库。。。。。")
  44. //初始化mysql
  45. entity.Mysql = &mysql.Mysql{
  46. Address: config.ConfigJson.DataSource.Address,
  47. UserName: config.ConfigJson.DataSource.UserName,
  48. PassWord: config.ConfigJson.DataSource.PassWord,
  49. DBName: config.ConfigJson.DataSource.DbName,
  50. MaxOpenConns: config.ConfigJson.DataSource.MaxOpenConns,
  51. MaxIdleConns: config.ConfigJson.DataSource.MaxIdleConns,
  52. }
  53. entity.Mysql.Init()
  54. data := entity.Mysql.Find("message_column", map[string]interface{}{"equity": "private_msg"}, "", "sequence", -1, -1)
  55. if data != nil && len(*data) > 0 {
  56. entity.MessageColumn = *data
  57. }
  58. //初始化 redis
  59. if config.ConfigJson.Redis.Addr != "" {
  60. if config.ConfigJson.Redis.Modules == "" {
  61. config.ConfigJson.Redis.Modules = "other"
  62. }
  63. log.Println("--初始化 redis--")
  64. redis.InitRedisBySize(fmt.Sprintf("%s=%s", config.ConfigJson.Redis.Modules, config.ConfigJson.Redis.Addr), 20, 30, 300)
  65. }
  66. // 初始化mongo
  67. if config.ConfigJson.Mongodb != nil {
  68. log.Println("初始化 mongodb main")
  69. entity.MQFW = m.MongodbSim{
  70. MongodbAddr: config.ConfigJson.Mongodb.Address,
  71. Size: config.ConfigJson.Mongodb.Size,
  72. DbName: config.ConfigJson.Mongodb.DbName,
  73. ReplSet: config.ConfigJson.Mongodb.ReplSet,
  74. }
  75. entity.MQFW.InitPool()
  76. }
  77. // 初始化消息保存并发通道
  78. entity.SaveConcurrencyChan = make(chan int, config.ConfigJson.SaveConcurrency)
  79. //初始化日志信息
  80. conf.MustLoad(*logFile, &logc)
  81. if len(logc.Level) > 0 {
  82. for _, v := range logc.Level {
  83. logx.MustSetup(logx.LogConf{
  84. Mode: logc.Mode,
  85. Path: logc.Path,
  86. Level: v,
  87. KeepDays: logc.KeepDays,
  88. })
  89. logx.Info(v, "--日志记录")
  90. }
  91. }
  92. if config.ConfigJson.SurvivalTime != 0 {
  93. entity.SurvivalTime = config.ConfigJson.SurvivalTime
  94. }
  95. }