Skip to content

Commit

Permalink
Obtain the channel from ChannelHandlerContext instead of HttpServerOp…
Browse files Browse the repository at this point in the history
…erations (#3231)

This is in addition to #3211
  • Loading branch information
violetagg authored May 7, 2024
1 parent 4fdac19 commit 022bccf
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -175,16 +175,13 @@ public void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise)

if (msg instanceof LastHttpContent) {
promise.addListener(future -> {
ChannelOperations<?, ?> channelOps = ChannelOperations.get(ctx.channel());
if (channelOps instanceof HttpServerOperations) {
try {
recordWrite((HttpServerOperations) channelOps);
}
catch (RuntimeException e) {
// Allow request-response exchange to continue, unaffected by metrics problem
if (log.isWarnEnabled()) {
log.warn(format(ctx.channel(), "Exception caught while recording metrics."), e);
}
try {
recordWrite(ctx.channel());
}
catch (RuntimeException e) {
// Allow request-response exchange to continue, unaffected by metrics problem
if (log.isWarnEnabled()) {
log.warn(format(ctx.channel(), "Exception caught while recording metrics."), e);
}
}

Expand Down Expand Up @@ -299,7 +296,7 @@ protected void recordRead() {
recorder().recordDataReceived(remoteSocketAddress, path, dataReceived);
}

protected void recordWrite(HttpServerOperations ops) {
protected void recordWrite(Channel channel) {
Duration dataSentTimeDuration = Duration.ofNanos(System.nanoTime() - dataSentTime);
recorder().recordDataSentTime(path, method, status, dataSentTimeDuration);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
*/
package reactor.netty.http.server;

import io.netty.channel.Channel;
import reactor.util.annotation.Nullable;
import reactor.util.context.ContextView;

Expand Down Expand Up @@ -72,7 +73,7 @@ protected void recordRead() {
}

@Override
protected void recordWrite(HttpServerOperations ops) {
protected void recordWrite(Channel channel) {
Duration dataSentTimeDuration = Duration.ofNanos(System.nanoTime() - dataSentTime);
recorder().recordDataSentTime(contextView, path, method, status, dataSentTimeDuration);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import io.micrometer.core.instrument.Timer;
import io.micrometer.observation.Observation;
import io.micrometer.observation.transport.RequestReplyReceiverContext;
import io.netty.channel.Channel;
import io.netty.handler.codec.http.HttpRequest;
import io.netty.handler.codec.http.HttpResponse;
import reactor.netty.observability.ReactorNettyHandlerContext;
Expand Down Expand Up @@ -85,7 +86,7 @@ protected HttpServerMetricsRecorder recorder() {
}

@Override
protected void recordWrite(HttpServerOperations ops) {
protected void recordWrite(Channel channel) {
Duration dataSentTimeDuration = Duration.ofNanos(System.nanoTime() - dataSentTime);
recorder().recordDataSentTime(path, method, status, dataSentTimeDuration);

Expand All @@ -100,7 +101,7 @@ protected void recordWrite(HttpServerOperations ops) {
// Move the implementation from the recorder here
responseTimeObservation.stop();

setChannelContext(ops.channel(), parentContextView);
setChannelContext(channel, parentContextView);

responseTimeHandlerContext = null;
responseTimeObservation = null;
Expand Down

0 comments on commit 022bccf

Please sign in to comment.