You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.go 3.1 kB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package main
  2. import (
  3. "fmt"
  4. "net"
  5. "os"
  6. "sync"
  7. distsvc "gitlink.org.cn/cloudream/common/pkgs/distlock/service"
  8. log "gitlink.org.cn/cloudream/common/pkgs/logger"
  9. "gitlink.org.cn/cloudream/storage-agent/internal/config"
  10. "gitlink.org.cn/cloudream/storage-agent/internal/task"
  11. "gitlink.org.cn/cloudream/storage-common/globals"
  12. agtrpc "gitlink.org.cn/cloudream/storage-common/pkgs/grpc/agent"
  13. "google.golang.org/grpc"
  14. agtmq "gitlink.org.cn/cloudream/storage-common/pkgs/mq/agent"
  15. grpcsvc "gitlink.org.cn/cloudream/storage-agent/internal/services/grpc"
  16. cmdsvc "gitlink.org.cn/cloudream/storage-agent/internal/services/mq"
  17. )
  18. // TODO 此数据是否在运行时会发生变化?
  19. var AgentIpList []string
  20. func main() {
  21. // TODO 放到配置里读取
  22. AgentIpList = []string{"pcm01", "pcm1", "pcm2"}
  23. err := config.Init()
  24. if err != nil {
  25. fmt.Printf("init config failed, err: %s", err.Error())
  26. os.Exit(1)
  27. }
  28. err = log.Init(&config.Cfg().Logger)
  29. if err != nil {
  30. fmt.Printf("init logger failed, err: %s", err.Error())
  31. os.Exit(1)
  32. }
  33. globals.InitLocal(&config.Cfg().Local)
  34. globals.InitMQPool(&config.Cfg().RabbitMQ)
  35. globals.InitAgentRPCPool(&agtrpc.PoolConfig{
  36. Port: config.Cfg().GRPC.Port,
  37. })
  38. globals.InitIPFSPool(&config.Cfg().IPFS)
  39. distlock, err := distsvc.NewService(&config.Cfg().DistLock)
  40. if err != nil {
  41. log.Fatalf("new ipfs failed, err: %s", err.Error())
  42. }
  43. //处置协调端、客户端命令(可多建几个)
  44. wg := sync.WaitGroup{}
  45. wg.Add(5)
  46. taskMgr := task.NewManager(distlock)
  47. // 启动命令服务器
  48. // TODO 需要设计AgentID持久化机制
  49. agtSvr, err := agtmq.NewServer(cmdsvc.NewService(&taskMgr), config.Cfg().ID, &config.Cfg().RabbitMQ)
  50. if err != nil {
  51. log.Fatalf("new agent server failed, err: %s", err.Error())
  52. }
  53. agtSvr.OnError = func(err error) {
  54. log.Warnf("agent server err: %s", err.Error())
  55. }
  56. go serveAgentServer(agtSvr, &wg)
  57. go reportStatus(&wg) //网络延迟感知
  58. //面向客户端收发数据
  59. listenAddr := config.Cfg().GRPC.MakeListenAddress()
  60. lis, err := net.Listen("tcp", listenAddr)
  61. if err != nil {
  62. log.Fatalf("listen on %s failed, err: %s", listenAddr, err.Error())
  63. }
  64. s := grpc.NewServer()
  65. agtrpc.RegisterAgentServer(s, grpcsvc.NewService())
  66. go serveGRPC(s, lis, &wg)
  67. go serveDistLock(distlock)
  68. wg.Wait()
  69. }
  70. func serveAgentServer(server *agtmq.Server, wg *sync.WaitGroup) {
  71. log.Info("start serving command server")
  72. err := server.Serve()
  73. if err != nil {
  74. log.Errorf("command server stopped with error: %s", err.Error())
  75. }
  76. log.Info("command server stopped")
  77. wg.Done()
  78. }
  79. func serveGRPC(s *grpc.Server, lis net.Listener, wg *sync.WaitGroup) {
  80. log.Info("start serving grpc")
  81. err := s.Serve(lis)
  82. if err != nil {
  83. log.Errorf("grpc stopped with error: %s", err.Error())
  84. }
  85. log.Info("grpc stopped")
  86. wg.Done()
  87. }
  88. func serveDistLock(svc *distsvc.Service) {
  89. log.Info("start serving distlock")
  90. err := svc.Serve()
  91. if err != nil {
  92. log.Errorf("distlock stopped with error: %s", err.Error())
  93. }
  94. log.Info("distlock stopped")
  95. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。