message.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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. "app.yhyue.com/moapp/jybase/mysql"
  11. "app.yhyue.com/moapp/jybase/redis"
  12. "flag"
  13. "fmt"
  14. "github.com/zeromicro/go-zero/core/conf"
  15. "github.com/zeromicro/go-zero/core/logx"
  16. "github.com/zeromicro/go-zero/zrpc"
  17. clientv3 "go.etcd.io/etcd/client/v3"
  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 EtcdCli *clientv3.Client
  25. var Mysql *mysql.Mysql
  26. var c config.Config
  27. func main() {
  28. flag.Parse()
  29. conf.MustLoad(*configFile, &c)
  30. ctx := svc.NewServiceContext(c)
  31. srv := server.NewMessageServer(ctx)
  32. s := zrpc.MustNewServer(c.RpcServerConf, func(grpcServer *grpc.Server) {
  33. message.RegisterMessageServer(grpcServer, srv)
  34. })
  35. defer s.Stop()
  36. fmt.Printf("Starting rpc server at %s...\n", c.ListenOn)
  37. s.Start()
  38. }
  39. // 创建orm引擎
  40. func init() {
  41. conf.MustLoad(*configFile, &config.ConfigJson)
  42. log.Println("开始初始化数据库。。。。。")
  43. //初始化mysql
  44. entity.Mysql = &mysql.Mysql{
  45. Address: config.ConfigJson.DataSource.Address,
  46. UserName: config.ConfigJson.DataSource.UserName,
  47. PassWord: config.ConfigJson.DataSource.PassWord,
  48. DBName: config.ConfigJson.DataSource.DbName,
  49. MaxOpenConns: config.ConfigJson.DataSource.MaxOpenConns,
  50. MaxIdleConns: config.ConfigJson.DataSource.MaxIdleConns,
  51. }
  52. entity.Mysql.Init()
  53. data := entity.Mysql.Find("message_column", map[string]interface{}{"equity": "private_msg"}, "", "sequence", -1, -1)
  54. if data != nil && len(*data) > 0 {
  55. entity.MessageColumn = *data
  56. }
  57. //初始化 redis
  58. if config.ConfigJson.Redis.Addr != "" {
  59. if config.ConfigJson.Redis.Modules == "" {
  60. config.ConfigJson.Redis.Modules = "other"
  61. }
  62. log.Println("--初始化 redis--")
  63. redis.InitRedisBySize(fmt.Sprintf("%s=%s", config.ConfigJson.Redis.Modules, config.ConfigJson.Redis.Addr), 20, 30, 300)
  64. }
  65. // 初始化消息保存并发通道
  66. entity.SaveConcurrencyChan = make(chan int, config.ConfigJson.SaveConcurrency)
  67. //初始化日志信息
  68. conf.MustLoad(*logFile, &logc)
  69. if len(logc.Level) > 0 {
  70. for _, v := range logc.Level {
  71. logx.MustSetup(logx.LogConf{
  72. Mode: logc.Mode,
  73. Path: logc.Path,
  74. Level: v,
  75. KeepDays: logc.KeepDays,
  76. })
  77. logx.Info(v, "--日志记录")
  78. }
  79. }
  80. if config.ConfigJson.SurvivalTime != 0 {
  81. entity.SurvivalTime = config.ConfigJson.SurvivalTime
  82. }
  83. }