tracing.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package quic
  2. import (
  3. "context"
  4. "net"
  5. "github.com/quic-go/quic-go/logging"
  6. "github.com/rs/zerolog"
  7. )
  8. // QUICTracer is a wrapper to create new quicConnTracer
  9. type tracer struct {
  10. index string
  11. logger *zerolog.Logger
  12. }
  13. func NewClientTracer(logger *zerolog.Logger, index uint8) func(context.Context, logging.Perspective, logging.ConnectionID) *logging.ConnectionTracer {
  14. t := &tracer{
  15. index: uint8ToString(index),
  16. logger: logger,
  17. }
  18. return t.TracerForConnection
  19. }
  20. func (t *tracer) TracerForConnection(_ctx context.Context, _p logging.Perspective, _odcid logging.ConnectionID) *logging.ConnectionTracer {
  21. return newConnTracer(newClientCollector(t.index, t.logger))
  22. }
  23. // connTracer collects connection level metrics
  24. type connTracer struct {
  25. metricsCollector *clientCollector
  26. }
  27. func newConnTracer(metricsCollector *clientCollector) *logging.ConnectionTracer {
  28. tracer := connTracer{
  29. metricsCollector: metricsCollector,
  30. }
  31. return &logging.ConnectionTracer{
  32. StartedConnection: tracer.StartedConnection,
  33. ClosedConnection: tracer.ClosedConnection,
  34. ReceivedTransportParameters: tracer.ReceivedTransportParameters,
  35. SentLongHeaderPacket: tracer.SentLongHeaderPacket,
  36. SentShortHeaderPacket: tracer.SentShortHeaderPacket,
  37. ReceivedLongHeaderPacket: tracer.ReceivedLongHeaderPacket,
  38. ReceivedShortHeaderPacket: tracer.ReceivedShortHeaderPacket,
  39. BufferedPacket: tracer.BufferedPacket,
  40. DroppedPacket: tracer.DroppedPacket,
  41. UpdatedMetrics: tracer.UpdatedMetrics,
  42. LostPacket: tracer.LostPacket,
  43. UpdatedMTU: tracer.UpdatedMTU,
  44. UpdatedCongestionState: tracer.UpdatedCongestionState,
  45. }
  46. }
  47. func (ct *connTracer) StartedConnection(local, remote net.Addr, srcConnID, destConnID logging.ConnectionID) {
  48. ct.metricsCollector.startedConnection()
  49. }
  50. func (ct *connTracer) ClosedConnection(err error) {
  51. ct.metricsCollector.closedConnection(err)
  52. }
  53. func (ct *connTracer) ReceivedTransportParameters(params *logging.TransportParameters) {
  54. ct.metricsCollector.receivedTransportParameters(params)
  55. }
  56. func (ct *connTracer) BufferedPacket(pt logging.PacketType, size logging.ByteCount) {
  57. ct.metricsCollector.bufferedPackets(pt)
  58. }
  59. func (ct *connTracer) DroppedPacket(pt logging.PacketType, number logging.PacketNumber, size logging.ByteCount, reason logging.PacketDropReason) {
  60. ct.metricsCollector.droppedPackets(pt, size, reason)
  61. }
  62. func (ct *connTracer) LostPacket(level logging.EncryptionLevel, number logging.PacketNumber, reason logging.PacketLossReason) {
  63. ct.metricsCollector.lostPackets(reason)
  64. }
  65. func (ct *connTracer) UpdatedMetrics(rttStats *logging.RTTStats, cwnd, bytesInFlight logging.ByteCount, packetsInFlight int) {
  66. ct.metricsCollector.updatedRTT(rttStats)
  67. ct.metricsCollector.updateCongestionWindow(cwnd)
  68. }
  69. func (ct *connTracer) SentLongHeaderPacket(hdr *logging.ExtendedHeader, size logging.ByteCount, ecn logging.ECN, ack *logging.AckFrame, frames []logging.Frame) {
  70. ct.metricsCollector.sentPackets(size, frames)
  71. }
  72. func (ct *connTracer) SentShortHeaderPacket(hdr *logging.ShortHeader, size logging.ByteCount, ecn logging.ECN, ack *logging.AckFrame, frames []logging.Frame) {
  73. ct.metricsCollector.sentPackets(size, frames)
  74. }
  75. func (ct *connTracer) ReceivedLongHeaderPacket(hdr *logging.ExtendedHeader, size logging.ByteCount, ecn logging.ECN, frames []logging.Frame) {
  76. ct.metricsCollector.receivedPackets(size, frames)
  77. }
  78. func (ct *connTracer) ReceivedShortHeaderPacket(hdr *logging.ShortHeader, size logging.ByteCount, ecn logging.ECN, frames []logging.Frame) {
  79. ct.metricsCollector.receivedPackets(size, frames)
  80. }
  81. func (ct *connTracer) UpdatedMTU(mtu logging.ByteCount, done bool) {
  82. ct.metricsCollector.updateMTU(mtu)
  83. }
  84. func (ct *connTracer) UpdatedCongestionState(state logging.CongestionState) {
  85. ct.metricsCollector.updatedCongestionState(state)
  86. }