mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 20:57:36 +03:00
implement qlogging of the preferred address in the transport parameters
This commit is contained in:
parent
272229abf0
commit
4372f46345
4 changed files with 66 additions and 1 deletions
|
@ -45,6 +45,8 @@ type (
|
||||||
ExtendedHeader = wire.ExtendedHeader
|
ExtendedHeader = wire.ExtendedHeader
|
||||||
// The TransportParameters are QUIC transport parameters.
|
// The TransportParameters are QUIC transport parameters.
|
||||||
TransportParameters = wire.TransportParameters
|
TransportParameters = wire.TransportParameters
|
||||||
|
// The PreferredAddress is the preferred address sent in the transport parameters.
|
||||||
|
PreferredAddress = wire.PreferredAddress
|
||||||
|
|
||||||
// A TransportError is a transport-level error code.
|
// A TransportError is a transport-level error code.
|
||||||
TransportError = qerr.ErrorCode
|
TransportError = qerr.ErrorCode
|
||||||
|
|
|
@ -352,7 +352,7 @@ type eventTransportParameters struct {
|
||||||
InitialMaxStreamsBidi int64
|
InitialMaxStreamsBidi int64
|
||||||
InitialMaxStreamsUni int64
|
InitialMaxStreamsUni int64
|
||||||
|
|
||||||
// TODO: add the preferred_address
|
PreferredAddress *preferredAddress
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e eventTransportParameters) Category() category { return categoryTransport }
|
func (e eventTransportParameters) Category() category { return categoryTransport }
|
||||||
|
@ -384,6 +384,29 @@ func (e eventTransportParameters) MarshalJSONObject(enc *gojay.Encoder) {
|
||||||
enc.Int64KeyOmitEmpty("initial_max_stream_data_uni", int64(e.InitialMaxStreamDataUni))
|
enc.Int64KeyOmitEmpty("initial_max_stream_data_uni", int64(e.InitialMaxStreamDataUni))
|
||||||
enc.Int64KeyOmitEmpty("initial_max_streams_bidi", e.InitialMaxStreamsBidi)
|
enc.Int64KeyOmitEmpty("initial_max_streams_bidi", e.InitialMaxStreamsBidi)
|
||||||
enc.Int64KeyOmitEmpty("initial_max_streams_uni", e.InitialMaxStreamsUni)
|
enc.Int64KeyOmitEmpty("initial_max_streams_uni", e.InitialMaxStreamsUni)
|
||||||
|
|
||||||
|
if e.PreferredAddress != nil {
|
||||||
|
enc.ObjectKey("preferred_address", e.PreferredAddress)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type preferredAddress struct {
|
||||||
|
IPv4, IPv6 net.IP
|
||||||
|
PortV4, PortV6 uint16
|
||||||
|
ConnectionID protocol.ConnectionID
|
||||||
|
StatelessResetToken protocol.StatelessResetToken
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ gojay.MarshalerJSONObject = &preferredAddress{}
|
||||||
|
|
||||||
|
func (a preferredAddress) IsNil() bool { return false }
|
||||||
|
func (a preferredAddress) MarshalJSONObject(enc *gojay.Encoder) {
|
||||||
|
enc.StringKey("ip_v4", a.IPv4.String())
|
||||||
|
enc.Uint16Key("port_v4", a.PortV4)
|
||||||
|
enc.StringKey("ip_v6", a.IPv6.String())
|
||||||
|
enc.Uint16Key("port_v6", a.PortV6)
|
||||||
|
enc.StringKey("connection_id", connectionID(a.ConnectionID).String())
|
||||||
|
enc.StringKey("stateless_reset_token", fmt.Sprintf("%x", a.StatelessResetToken))
|
||||||
}
|
}
|
||||||
|
|
||||||
type eventLossTimerSet struct {
|
type eventLossTimerSet struct {
|
||||||
|
|
12
qlog/qlog.go
12
qlog/qlog.go
|
@ -188,6 +188,17 @@ func (t *connectionTracer) recordTransportParameters(sentBy protocol.Perspective
|
||||||
if sentBy != t.perspective {
|
if sentBy != t.perspective {
|
||||||
owner = ownerRemote
|
owner = ownerRemote
|
||||||
}
|
}
|
||||||
|
var pa *preferredAddress
|
||||||
|
if tp.PreferredAddress != nil {
|
||||||
|
pa = &preferredAddress{
|
||||||
|
IPv4: tp.PreferredAddress.IPv4,
|
||||||
|
PortV4: tp.PreferredAddress.IPv4Port,
|
||||||
|
IPv6: tp.PreferredAddress.IPv6,
|
||||||
|
PortV6: tp.PreferredAddress.IPv6Port,
|
||||||
|
ConnectionID: tp.PreferredAddress.ConnectionID,
|
||||||
|
StatelessResetToken: tp.PreferredAddress.StatelessResetToken,
|
||||||
|
}
|
||||||
|
}
|
||||||
t.mutex.Lock()
|
t.mutex.Lock()
|
||||||
t.recordEvent(time.Now(), &eventTransportParameters{
|
t.recordEvent(time.Now(), &eventTransportParameters{
|
||||||
Owner: owner,
|
Owner: owner,
|
||||||
|
@ -208,6 +219,7 @@ func (t *connectionTracer) recordTransportParameters(sentBy protocol.Perspective
|
||||||
InitialMaxStreamDataUni: tp.InitialMaxStreamDataUni,
|
InitialMaxStreamDataUni: tp.InitialMaxStreamDataUni,
|
||||||
InitialMaxStreamsBidi: int64(tp.MaxBidiStreamNum),
|
InitialMaxStreamsBidi: int64(tp.MaxBidiStreamNum),
|
||||||
InitialMaxStreamsUni: int64(tp.MaxUniStreamNum),
|
InitialMaxStreamsUni: int64(tp.MaxUniStreamNum),
|
||||||
|
PreferredAddress: pa,
|
||||||
})
|
})
|
||||||
t.mutex.Unlock()
|
t.mutex.Unlock()
|
||||||
}
|
}
|
||||||
|
|
|
@ -232,6 +232,7 @@ var _ = Describe("Tracing", func() {
|
||||||
Expect(ev).To(HaveKeyWithValue("initial_max_stream_data_uni", float64(3000)))
|
Expect(ev).To(HaveKeyWithValue("initial_max_stream_data_uni", float64(3000)))
|
||||||
Expect(ev).To(HaveKeyWithValue("initial_max_streams_bidi", float64(10)))
|
Expect(ev).To(HaveKeyWithValue("initial_max_streams_bidi", float64(10)))
|
||||||
Expect(ev).To(HaveKeyWithValue("initial_max_streams_uni", float64(20)))
|
Expect(ev).To(HaveKeyWithValue("initial_max_streams_uni", float64(20)))
|
||||||
|
Expect(ev).ToNot(HaveKey("preferred_address"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("records the server's transport parameters, without a stateless reset token", func() {
|
It("records the server's transport parameters, without a stateless reset token", func() {
|
||||||
|
@ -260,6 +261,33 @@ var _ = Describe("Tracing", func() {
|
||||||
Expect(ev).ToNot(HaveKey("retry_source_connection_id"))
|
Expect(ev).ToNot(HaveKey("retry_source_connection_id"))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("records transport parameters with a preferred address", func() {
|
||||||
|
tracer.SentTransportParameters(&logging.TransportParameters{
|
||||||
|
PreferredAddress: &logging.PreferredAddress{
|
||||||
|
IPv4: net.IPv4(12, 34, 56, 78),
|
||||||
|
IPv4Port: 123,
|
||||||
|
IPv6: net.IP{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16},
|
||||||
|
IPv6Port: 456,
|
||||||
|
ConnectionID: protocol.ConnectionID{8, 7, 6, 5, 4, 3, 2, 1},
|
||||||
|
StatelessResetToken: protocol.StatelessResetToken{15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
entry := exportAndParseSingle()
|
||||||
|
Expect(entry.Time).To(BeTemporally("~", time.Now(), scaleDuration(10*time.Millisecond)))
|
||||||
|
Expect(entry.Category).To(Equal("transport"))
|
||||||
|
Expect(entry.Name).To(Equal("parameters_set"))
|
||||||
|
ev := entry.Event
|
||||||
|
Expect(ev).To(HaveKeyWithValue("owner", "local"))
|
||||||
|
Expect(ev).To(HaveKey("preferred_address"))
|
||||||
|
pa := ev["preferred_address"].(map[string]interface{})
|
||||||
|
Expect(pa).To(HaveKeyWithValue("ip_v4", "12.34.56.78"))
|
||||||
|
Expect(pa).To(HaveKeyWithValue("port_v4", float64(123)))
|
||||||
|
Expect(pa).To(HaveKeyWithValue("ip_v6", "102:304:506:708:90a:b0c:d0e:f10"))
|
||||||
|
Expect(pa).To(HaveKeyWithValue("port_v6", float64(456)))
|
||||||
|
Expect(pa).To(HaveKeyWithValue("connection_id", "0807060504030201"))
|
||||||
|
Expect(pa).To(HaveKeyWithValue("stateless_reset_token", "0f0e0d0c0b0a09080706050403020100"))
|
||||||
|
})
|
||||||
|
|
||||||
It("records received transport parameters", func() {
|
It("records received transport parameters", func() {
|
||||||
tracer.ReceivedTransportParameters(&logging.TransportParameters{})
|
tracer.ReceivedTransportParameters(&logging.TransportParameters{})
|
||||||
entry := exportAndParseSingle()
|
entry := exportAndParseSingle()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue