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 1.3 kB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package main
  2. import (
  3. "fmt"
  4. "net"
  5. "os"
  6. "sync"
  7. "gitlink.org.cn/cloudream/agent/config"
  8. agentserver "gitlink.org.cn/cloudream/proto"
  9. "gitlink.org.cn/cloudream/utils/logger"
  10. "google.golang.org/grpc"
  11. rasvr "gitlink.org.cn/cloudream/rabbitmq/server"
  12. )
  13. // TODO 此数据是否在运行时会发生变化?
  14. var AgentIpList []string
  15. func main() {
  16. err := config.Init()
  17. if err != nil {
  18. fmt.Printf("init config failed, err: %s", err.Error())
  19. os.Exit(1)
  20. }
  21. err = logger.Init(&config.Cfg().Logger)
  22. if err != nil {
  23. fmt.Printf("init logger failed, err: %s", err.Error())
  24. os.Exit(1)
  25. }
  26. AgentIpList = []string{"pcm01", "pcm1", "pcm2"}
  27. //处置协调端、客户端命令(可多建几个)
  28. wg := sync.WaitGroup{}
  29. wg.Add(2)
  30. // 启动命令服务器
  31. cmdSvr, err := rasvr.NewAgentServer(&CommandService{}, config.Cfg().LocalIP)
  32. if err != nil {
  33. // TODO 错误日志
  34. return
  35. }
  36. go serveCommandServer(cmdSvr, &wg)
  37. go reportStatus(&wg) //网络延迟感知
  38. //面向客户端收发数据
  39. lis, err := net.Listen("tcp", fmt.Sprintf("127.0.0.1:%d", config.Cfg().GRPCPort))
  40. if err != nil {
  41. panic(err)
  42. }
  43. s := grpc.NewServer()
  44. agentserver.RegisterTranBlockOrReplicaServer(s, &anyOne{})
  45. s.Serve(lis)
  46. wg.Wait()
  47. }
  48. func serveCommandServer(server *rasvr.AgentServer, wg *sync.WaitGroup) {
  49. server.Serve()
  50. wg.Done()
  51. }

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