3
0

message_metrics.go 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package nebula
  2. import (
  3. "fmt"
  4. "github.com/rcrowley/go-metrics"
  5. )
  6. type MessageMetrics struct {
  7. rx [][]metrics.Counter
  8. tx [][]metrics.Counter
  9. rxUnknown metrics.Counter
  10. txUnknown metrics.Counter
  11. }
  12. func (m *MessageMetrics) Rx(t NebulaMessageType, s NebulaMessageSubType, i int64) {
  13. if m != nil {
  14. if t >= 0 && int(t) < len(m.rx) && s >= 0 && int(s) < len(m.rx[t]) {
  15. m.rx[t][s].Inc(i)
  16. } else if m.rxUnknown != nil {
  17. m.rxUnknown.Inc(i)
  18. }
  19. }
  20. }
  21. func (m *MessageMetrics) Tx(t NebulaMessageType, s NebulaMessageSubType, i int64) {
  22. if m != nil {
  23. if t >= 0 && int(t) < len(m.tx) && s >= 0 && int(s) < len(m.tx[t]) {
  24. m.tx[t][s].Inc(i)
  25. } else if m.txUnknown != nil {
  26. m.txUnknown.Inc(i)
  27. }
  28. }
  29. }
  30. func newMessageMetrics() *MessageMetrics {
  31. gen := func(t string) [][]metrics.Counter {
  32. return [][]metrics.Counter{
  33. {
  34. metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.handshake_ixpsk0", t), nil),
  35. },
  36. nil,
  37. {metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.recv_error", t), nil)},
  38. {metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.lighthouse", t), nil)},
  39. {
  40. metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.test_request", t), nil),
  41. metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.test_response", t), nil),
  42. },
  43. {metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.close_tunnel", t), nil)},
  44. }
  45. }
  46. return &MessageMetrics{
  47. rx: gen("rx"),
  48. tx: gen("tx"),
  49. rxUnknown: metrics.GetOrRegisterCounter("messages.rx.other", nil),
  50. txUnknown: metrics.GetOrRegisterCounter("messages.tx.other", nil),
  51. }
  52. }
  53. // Historically we only recorded recv_error, so this is backwards compat
  54. func newMessageMetricsOnlyRecvError() *MessageMetrics {
  55. gen := func(t string) [][]metrics.Counter {
  56. return [][]metrics.Counter{
  57. nil,
  58. nil,
  59. {metrics.GetOrRegisterCounter(fmt.Sprintf("messages.%s.recv_error", t), nil)},
  60. }
  61. }
  62. return &MessageMetrics{
  63. rx: gen("rx"),
  64. tx: gen("tx"),
  65. }
  66. }
  67. func newLighthouseMetrics() *MessageMetrics {
  68. gen := func(t string) [][]metrics.Counter {
  69. h := make([][]metrics.Counter, len(NebulaMeta_MessageType_name))
  70. used := []NebulaMeta_MessageType{
  71. NebulaMeta_HostQuery,
  72. NebulaMeta_HostQueryReply,
  73. NebulaMeta_HostUpdateNotification,
  74. NebulaMeta_HostPunchNotification,
  75. }
  76. for _, i := range used {
  77. h[i] = []metrics.Counter{metrics.GetOrRegisterCounter(fmt.Sprintf("lighthouse.%s.%s", t, i.String()), nil)}
  78. }
  79. return h
  80. }
  81. return &MessageMetrics{
  82. rx: gen("rx"),
  83. tx: gen("tx"),
  84. rxUnknown: metrics.GetOrRegisterCounter("lighthouse.rx.other", nil),
  85. txUnknown: metrics.GetOrRegisterCounter("lighthouse.tx.other", nil),
  86. }
  87. }