message.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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/common"
  7. "app.yhyue.com/moapp/MessageCenter/rpc/internal/config"
  8. "app.yhyue.com/moapp/MessageCenter/rpc/internal/server"
  9. "app.yhyue.com/moapp/MessageCenter/rpc/internal/svc"
  10. "app.yhyue.com/moapp/MessageCenter/rpc/type/message"
  11. mc "app.yhyue.com/moapp/jybase/common"
  12. "app.yhyue.com/moapp/jybase/endless"
  13. "app.yhyue.com/moapp/jybase/mail"
  14. m "app.yhyue.com/moapp/jybase/mongodb"
  15. "app.yhyue.com/moapp/jybase/mysql"
  16. "app.yhyue.com/moapp/jybase/redis"
  17. "flag"
  18. "fmt"
  19. "github.com/go-xorm/xorm"
  20. "github.com/zeromicro/go-zero/core/conf"
  21. "github.com/zeromicro/go-zero/core/logx"
  22. "github.com/zeromicro/go-zero/zrpc"
  23. "google.golang.org/grpc"
  24. "log"
  25. )
  26. var configFile = flag.String("f", "etc/message.yaml", "the config file")
  27. var logFile = flag.String("lf", "etc/logs.yaml", "the logs file")
  28. var logc entity.Logc
  29. var c config.Config
  30. func main() {
  31. flag.Parse()
  32. conf.MustLoad(*configFile, &c)
  33. go common.SaveTask()
  34. go func() {
  35. err := endless.ListenAndServe(":"+mc.InterfaceToStr(c.WebRpcPort), nil, func() {})
  36. if err != nil {
  37. log.Println("ListenAndServe: ", err)
  38. }
  39. }()
  40. ctx := svc.NewServiceContext(c)
  41. srv := server.NewMessageServer(ctx)
  42. s := zrpc.MustNewServer(c.RpcServerConf, func(grpcServer *grpc.Server) {
  43. message.RegisterMessageServer(grpcServer, srv)
  44. })
  45. defer s.Stop()
  46. fmt.Printf("Starting rpc server at %s...\n", c.ListenOn)
  47. s.Start()
  48. }
  49. // 创建orm引擎
  50. func init() {
  51. conf.MustLoad(*configFile, &config.ConfigJson)
  52. log.Println("开始初始化数据库。。。。。")
  53. //初始化mysql
  54. entity.Mysql = &mysql.Mysql{
  55. Address: config.ConfigJson.DataSource.Address,
  56. UserName: config.ConfigJson.DataSource.UserName,
  57. PassWord: config.ConfigJson.DataSource.PassWord,
  58. DBName: config.ConfigJson.DataSource.DbName,
  59. MaxOpenConns: config.ConfigJson.DataSource.MaxOpenConns,
  60. MaxIdleConns: config.ConfigJson.DataSource.MaxIdleConns,
  61. }
  62. entity.Mysql.Init()
  63. common.AllMsgType, entity.MessageColumn = common.MessageType()
  64. // 初始化需要展示消息细化分类的groupid 和对应的class信息
  65. common.InitClassSearchMap()
  66. //初始化basemysql
  67. entity.BaseMysql = &mysql.Mysql{
  68. Address: config.ConfigJson.BaseSource.Address,
  69. UserName: config.ConfigJson.BaseSource.UserName,
  70. PassWord: config.ConfigJson.BaseSource.PassWord,
  71. DBName: config.ConfigJson.BaseSource.DbName,
  72. MaxOpenConns: config.ConfigJson.BaseSource.MaxOpenConns,
  73. MaxIdleConns: config.ConfigJson.BaseSource.MaxIdleConns,
  74. }
  75. entity.BaseMysql.Init()
  76. //初始化 redis
  77. if config.ConfigJson.RedisAddr != "" {
  78. redis.InitRedis(config.ConfigJson.RedisAddr)
  79. }
  80. // 初始化mongo
  81. if config.ConfigJson.Mongodb != nil {
  82. log.Println("初始化 mongodb main")
  83. entity.MQFW = m.MongodbSim{
  84. MongodbAddr: config.ConfigJson.Mongodb.Address,
  85. Size: config.ConfigJson.Mongodb.Size,
  86. DbName: config.ConfigJson.Mongodb.DbName,
  87. ReplSet: config.ConfigJson.Mongodb.ReplSet,
  88. }
  89. entity.MQFW.InitPool()
  90. }
  91. // 初始化发送邮件
  92. for _, v := range config.ConfigJson.Mail {
  93. entity.GmailAuth = append(entity.GmailAuth, &mail.GmailAuth{
  94. SmtpHost: v.Addr,
  95. SmtpPort: v.Port,
  96. User: v.User,
  97. Pwd: v.Pwd,
  98. })
  99. }
  100. // 初始化消息保存并发通道
  101. entity.SaveConcurrencyChan = make(chan int, config.ConfigJson.SaveConcurrency)
  102. //初始化日志信息
  103. conf.MustLoad(*logFile, &logc)
  104. if len(logc.Level) > 0 {
  105. for _, v := range logc.Level {
  106. logx.MustSetup(logx.LogConf{
  107. Mode: logc.Mode,
  108. Path: logc.Path,
  109. Level: v,
  110. KeepDays: logc.KeepDays,
  111. })
  112. logx.Info(v, "--日志记录")
  113. }
  114. }
  115. if config.ConfigJson.SurvivalTime != 0 {
  116. entity.SurvivalTime = config.ConfigJson.SurvivalTime
  117. }
  118. entity.Engine, _ = xorm.NewEngine("mysql", config.ConfigJson.TidbEng)
  119. entity.Engine.ShowSQL(true)
  120. }