message.go 3.0 KB

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