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.

agent_check_state.go 2.9 kB

2 years ago
2 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package event
  2. import (
  3. "database/sql"
  4. "time"
  5. "gitlink.org.cn/cloudream/common/pkgs/logger"
  6. "gitlink.org.cn/cloudream/common/pkgs/mq"
  7. "gitlink.org.cn/cloudream/storage/common/consts"
  8. stgglb "gitlink.org.cn/cloudream/storage/common/globals"
  9. agtmq "gitlink.org.cn/cloudream/storage/common/pkgs/mq/agent"
  10. scevt "gitlink.org.cn/cloudream/storage/common/pkgs/mq/scanner/event"
  11. "gitlink.org.cn/cloudream/storage/scanner/internal/config"
  12. )
  13. type AgentCheckState struct {
  14. *scevt.AgentCheckState
  15. }
  16. func NewAgentCheckState(evt *scevt.AgentCheckState) *AgentCheckState {
  17. return &AgentCheckState{
  18. AgentCheckState: evt,
  19. }
  20. }
  21. func (t *AgentCheckState) TryMerge(other Event) bool {
  22. event, ok := other.(*AgentCheckState)
  23. if !ok {
  24. return false
  25. }
  26. return t.NodeID == event.NodeID
  27. }
  28. func (t *AgentCheckState) Execute(execCtx ExecuteContext) {
  29. log := logger.WithType[AgentCheckState]("Event")
  30. log.Debugf("begin with %v", logger.FormatStruct(t.AgentCheckState))
  31. defer log.Debugf("end")
  32. node, err := execCtx.Args.DB.Node().GetByID(execCtx.Args.DB.SQLCtx(), t.NodeID)
  33. if err == sql.ErrNoRows {
  34. return
  35. }
  36. if err != nil {
  37. log.WithField("NodeID", t.NodeID).Warnf("get node by id failed, err: %s", err.Error())
  38. return
  39. }
  40. agtCli, err := stgglb.AgentMQPool.Acquire(t.NodeID)
  41. if err != nil {
  42. log.WithField("NodeID", t.NodeID).Warnf("create agent client failed, err: %s", err.Error())
  43. return
  44. }
  45. defer stgglb.AgentMQPool.Release(agtCli)
  46. getResp, err := agtCli.GetState(agtmq.NewGetState(), mq.RequestOption{Timeout: time.Second * 30})
  47. if err != nil {
  48. log.WithField("NodeID", t.NodeID).Warnf("getting state: %s", err.Error())
  49. // 检查上次上报时间,超时的设置为不可用
  50. // TODO 没有上报过是否要特殊处理?
  51. if node.LastReportTime != nil && time.Since(*node.LastReportTime) > time.Duration(config.Cfg().NodeUnavailableSeconds)*time.Second {
  52. err := execCtx.Args.DB.Node().UpdateState(execCtx.Args.DB.SQLCtx(), t.NodeID, consts.NodeStateUnavailable)
  53. if err != nil {
  54. log.WithField("NodeID", t.NodeID).Warnf("set node state failed, err: %s", err.Error())
  55. }
  56. }
  57. return
  58. }
  59. // 根据返回结果修改节点状态
  60. if getResp.IPFSState != consts.IPFSStateOK {
  61. log.WithField("NodeID", t.NodeID).Warnf("IPFS status is %s, set node state unavailable", getResp.IPFSState)
  62. err := execCtx.Args.DB.Node().UpdateState(execCtx.Args.DB.SQLCtx(), t.NodeID, consts.NodeStateUnavailable)
  63. if err != nil {
  64. log.WithField("NodeID", t.NodeID).Warnf("change node state failed, err: %s", err.Error())
  65. }
  66. return
  67. }
  68. // TODO 如果以后还有其他的状态,要判断哪些状态下能设置Normal
  69. err = execCtx.Args.DB.Node().UpdateState(execCtx.Args.DB.SQLCtx(), t.NodeID, consts.NodeStateNormal)
  70. if err != nil {
  71. log.WithField("NodeID", t.NodeID).Warnf("change node state failed, err: %s", err.Error())
  72. }
  73. }
  74. func init() {
  75. RegisterMessageConvertor(NewAgentCheckState)
  76. }

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