Skip to content

Commit 8835593

Browse files
committed
Merge pull request #41333 from eddumelendez
* pr/41333: Polish "Support Otlp Tracing's GRPC port from service connections" Support Otlp Tracing's GRPC port from service connections Closes gh-41333
2 parents f6505f7 + bac3303 commit 8835593

File tree

11 files changed

+79
-21
lines changed

11 files changed

+79
-21
lines changed

spring-boot-project/spring-boot-actuator-autoconfigure/src/main/java/org/springframework/boot/actuate/autoconfigure/tracing/otlp/OtlpTracingConfigurations.java

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -23,17 +23,20 @@
2323
import io.opentelemetry.exporter.otlp.trace.OtlpGrpcSpanExporter;
2424
import io.opentelemetry.exporter.otlp.trace.OtlpGrpcSpanExporterBuilder;
2525

26+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
2627
import org.springframework.boot.actuate.autoconfigure.tracing.ConditionalOnEnabledTracing;
2728
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
2829
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
2930
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
3031
import org.springframework.context.annotation.Bean;
3132
import org.springframework.context.annotation.Configuration;
33+
import org.springframework.util.Assert;
3234

3335
/**
3436
* Configurations imported by {@link OtlpAutoConfiguration}.
3537
*
3638
* @author Moritz Halbritter
39+
* @author Eddú Meléndez
3740
*/
3841
class OtlpTracingConfigurations {
3942

@@ -59,7 +62,10 @@ static class PropertiesOtlpTracingConnectionDetails implements OtlpTracingConnec
5962
}
6063

6164
@Override
62-
public String getUrl() {
65+
public String getUrl(Transport transport) {
66+
Assert.state(transport == this.properties.getTransport(),
67+
"Requested transport %s doesn't match configured transport %s".formatted(transport,
68+
this.properties.getTransport()));
6369
return this.properties.getEndpoint();
6470
}
6571

@@ -79,7 +85,7 @@ static class Exporters {
7985
OtlpHttpSpanExporter otlpHttpSpanExporter(OtlpProperties properties,
8086
OtlpTracingConnectionDetails connectionDetails) {
8187
OtlpHttpSpanExporterBuilder builder = OtlpHttpSpanExporter.builder()
82-
.setEndpoint(connectionDetails.getUrl())
88+
.setEndpoint(connectionDetails.getUrl(Transport.HTTP))
8389
.setTimeout(properties.getTimeout())
8490
.setCompression(properties.getCompression().name().toLowerCase());
8591
for (Entry<String, String> header : properties.getHeaders().entrySet()) {
@@ -93,7 +99,7 @@ OtlpHttpSpanExporter otlpHttpSpanExporter(OtlpProperties properties,
9399
OtlpGrpcSpanExporter otlpGrpcSpanExporter(OtlpProperties properties,
94100
OtlpTracingConnectionDetails connectionDetails) {
95101
OtlpGrpcSpanExporterBuilder builder = OtlpGrpcSpanExporter.builder()
96-
.setEndpoint(connectionDetails.getUrl())
102+
.setEndpoint(connectionDetails.getUrl(Transport.GRPC))
97103
.setTimeout(properties.getTimeout())
98104
.setCompression(properties.getCompression().name().toLowerCase());
99105
for (Entry<String, String> header : properties.getHeaders().entrySet()) {

spring-boot-project/spring-boot-actuator-autoconfigure/src/main/java/org/springframework/boot/actuate/autoconfigure/tracing/otlp/OtlpTracingConnectionDetails.java

Lines changed: 16 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2012-2023 the original author or authors.
2+
* Copyright 2012-2024 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -16,20 +16,34 @@
1616

1717
package org.springframework.boot.actuate.autoconfigure.tracing.otlp;
1818

19+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
1920
import org.springframework.boot.autoconfigure.service.connection.ConnectionDetails;
2021

2122
/**
2223
* Details required to establish a connection to an OpenTelemetry service.
2324
*
2425
* @author Eddú Meléndez
26+
* @author Moritz Halbritter
2527
* @since 3.2.0
2628
*/
2729
public interface OtlpTracingConnectionDetails extends ConnectionDetails {
2830

2931
/**
3032
* Address to where tracing will be published.
3133
* @return the address to where tracing will be published
34+
* @deprecated since 3.4.0 for removal in 3.6.0 in favor of {@link #getUrl(Transport)}
3235
*/
33-
String getUrl();
36+
@Deprecated(since = "3.4.0", forRemoval = true)
37+
default String getUrl() {
38+
return getUrl(Transport.HTTP);
39+
}
40+
41+
/**
42+
* Address to where tracing will be published.
43+
* @param transport the transport to use
44+
* @return the address to where tracing will be published
45+
* @since 3.4.0
46+
*/
47+
String getUrl(Transport transport);
3448

3549
}

spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/tracing/otlp/OtlpAutoConfigurationTests.java

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -172,7 +172,7 @@ static class ConnectionDetailsConfiguration {
172172

173173
@Bean
174174
OtlpTracingConnectionDetails otlpTracingConnectionDetails() {
175-
return () -> "http://localhost:12345/v1/traces";
175+
return (transport) -> "http://localhost:12345/v1/traces";
176176
}
177177

178178
}

spring-boot-project/spring-boot-docker-compose/src/dockerTest/java/org/springframework/boot/docker/compose/service/connection/otlp/GrafanaOpenTelemetryTracingDockerComposeConnectionDetailsFactoryIntegrationTests.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616

1717
package org.springframework.boot.docker.compose.service.connection.otlp;
1818

19+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
1920
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2021
import org.springframework.boot.docker.compose.service.connection.test.DockerComposeTest;
2122
import org.springframework.boot.testsupport.container.TestImage;
@@ -32,7 +33,8 @@ class GrafanaOpenTelemetryTracingDockerComposeConnectionDetailsFactoryIntegratio
3233

3334
@DockerComposeTest(composeFile = "otlp-compose.yaml", image = TestImage.GRAFANA_OTEL_LGTM)
3435
void runCreatesConnectionDetails(OtlpTracingConnectionDetails connectionDetails) {
35-
assertThat(connectionDetails.getUrl()).startsWith("http://").endsWith("/v1/traces");
36+
assertThat(connectionDetails.getUrl(Transport.HTTP)).startsWith("http://").endsWith("/v1/traces");
37+
assertThat(connectionDetails.getUrl(Transport.GRPC)).startsWith("http://").endsWith("/v1/traces");
3638
}
3739

3840
}

spring-boot-project/spring-boot-docker-compose/src/dockerTest/java/org/springframework/boot/docker/compose/service/connection/otlp/OpenTelemetryTracingDockerComposeConnectionDetailsFactoryIntegrationTests.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616

1717
package org.springframework.boot.docker.compose.service.connection.otlp;
1818

19+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
1920
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2021
import org.springframework.boot.docker.compose.service.connection.test.DockerComposeTest;
2122
import org.springframework.boot.testsupport.container.TestImage;
@@ -32,7 +33,8 @@ class OpenTelemetryTracingDockerComposeConnectionDetailsFactoryIntegrationTests
3233

3334
@DockerComposeTest(composeFile = "otlp-compose.yaml", image = TestImage.OPENTELEMETRY)
3435
void runCreatesConnectionDetails(OtlpTracingConnectionDetails connectionDetails) {
35-
assertThat(connectionDetails.getUrl()).startsWith("http://").endsWith("/v1/traces");
36+
assertThat(connectionDetails.getUrl(Transport.HTTP)).startsWith("http://").endsWith("/v1/traces");
37+
assertThat(connectionDetails.getUrl(Transport.GRPC)).startsWith("http://").endsWith("/v1/traces");
3638
}
3739

3840
}

spring-boot-project/spring-boot-docker-compose/src/dockerTest/resources/org/springframework/boot/docker/compose/service/connection/otlp/otlp-compose.yaml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,5 @@ services:
22
otlp:
33
image: '{imageName}'
44
ports:
5+
- '4317'
56
- '4318'

spring-boot-project/spring-boot-docker-compose/src/main/java/org/springframework/boot/docker/compose/service/connection/otlp/OpenTelemetryTracingDockerComposeConnectionDetailsFactory.java

Lines changed: 16 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616

1717
package org.springframework.boot.docker.compose.service.connection.otlp;
1818

19+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
1920
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2021
import org.springframework.boot.docker.compose.core.RunningService;
2122
import org.springframework.boot.docker.compose.service.connection.DockerComposeConnectionDetailsFactory;
@@ -26,14 +27,17 @@
2627
* {@link OtlpTracingConnectionDetails} for an OTLP service.
2728
*
2829
* @author Eddú Meléndez
30+
* @author Moritz Halbritter
2931
*/
3032
class OpenTelemetryTracingDockerComposeConnectionDetailsFactory
3133
extends DockerComposeConnectionDetailsFactory<OtlpTracingConnectionDetails> {
3234

3335
private static final String[] OPENTELEMETRY_IMAGE_NAMES = { "otel/opentelemetry-collector-contrib",
3436
"grafana/otel-lgtm" };
3537

36-
private static final int OTLP_PORT = 4318;
38+
private static final int OTLP_GRPC_PORT = 4317;
39+
40+
private static final int OTLP_HTTP_PORT = 4318;
3741

3842
OpenTelemetryTracingDockerComposeConnectionDetailsFactory() {
3943
super(OPENTELEMETRY_IMAGE_NAMES,
@@ -50,17 +54,24 @@ private static final class OpenTelemetryTracingDockerComposeConnectionDetails ex
5054

5155
private final String host;
5256

53-
private final int port;
57+
private final int grpcPort;
58+
59+
private final int httPort;
5460

5561
private OpenTelemetryTracingDockerComposeConnectionDetails(RunningService source) {
5662
super(source);
5763
this.host = source.host();
58-
this.port = source.ports().get(OTLP_PORT);
64+
this.grpcPort = source.ports().get(OTLP_GRPC_PORT);
65+
this.httPort = source.ports().get(OTLP_HTTP_PORT);
5966
}
6067

6168
@Override
62-
public String getUrl() {
63-
return "http://%s:%d/v1/traces".formatted(this.host, this.port);
69+
public String getUrl(Transport transport) {
70+
int port = switch (transport) {
71+
case HTTP -> this.httPort;
72+
case GRPC -> this.grpcPort;
73+
};
74+
return "http://%s:%d/v1/traces".formatted(this.host, port);
6475
}
6576

6677
}

spring-boot-project/spring-boot-testcontainers/src/dockerTest/java/org/springframework/boot/testcontainers/service/connection/otlp/GrafanaOpenTelemetryTracingContainerConnectionDetailsFactoryIntegrationTests.java

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
import org.testcontainers.junit.jupiter.Testcontainers;
2323

2424
import org.springframework.beans.factory.annotation.Autowired;
25+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
2526
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpAutoConfiguration;
2627
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2728
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
@@ -50,7 +51,10 @@ class GrafanaOpenTelemetryTracingContainerConnectionDetailsFactoryIntegrationTes
5051

5152
@Test
5253
void connectionCanBeMadeToOpenTelemetryContainer() {
53-
assertThat(this.connectionDetails.getUrl()).isEqualTo("%s/v1/traces".formatted(container.getOtlpHttpUrl()));
54+
assertThat(this.connectionDetails.getUrl(Transport.HTTP))
55+
.isEqualTo("%s/v1/traces".formatted(container.getOtlpHttpUrl()));
56+
assertThat(this.connectionDetails.getUrl(Transport.GRPC))
57+
.isEqualTo("%s/v1/traces".formatted(container.getOtlpGrpcUrl()));
5458
}
5559

5660
@Configuration(proxyBeanMethods = false)

spring-boot-project/spring-boot-testcontainers/src/dockerTest/java/org/springframework/boot/testcontainers/service/connection/otlp/OpenTelemetryTracingContainerConnectionDetailsFactoryIntegrationTests.java

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
import org.testcontainers.junit.jupiter.Testcontainers;
2323

2424
import org.springframework.beans.factory.annotation.Autowired;
25+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
2526
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpAutoConfiguration;
2627
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2728
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
@@ -43,15 +44,18 @@ class OpenTelemetryTracingContainerConnectionDetailsFactoryIntegrationTests {
4344

4445
@Container
4546
@ServiceConnection
46-
static final GenericContainer<?> container = TestImage.OPENTELEMETRY.genericContainer().withExposedPorts(4318);
47+
static final GenericContainer<?> container = TestImage.OPENTELEMETRY.genericContainer()
48+
.withExposedPorts(4317, 4318);
4749

4850
@Autowired
4951
private OtlpTracingConnectionDetails connectionDetails;
5052

5153
@Test
5254
void connectionCanBeMadeToOpenTelemetryContainer() {
53-
assertThat(this.connectionDetails.getUrl())
55+
assertThat(this.connectionDetails.getUrl(Transport.HTTP))
5456
.isEqualTo("http://" + container.getHost() + ":" + container.getMappedPort(4318) + "/v1/traces");
57+
assertThat(this.connectionDetails.getUrl(Transport.GRPC))
58+
.isEqualTo("http://" + container.getHost() + ":" + container.getMappedPort(4317) + "/v1/traces");
5559
}
5660

5761
@Configuration(proxyBeanMethods = false)

spring-boot-project/spring-boot-testcontainers/src/main/java/org/springframework/boot/testcontainers/service/connection/otlp/GrafanaOpenTelemetryTracingContainerConnectionDetailsFactory.java

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@
1818

1919
import org.testcontainers.grafana.LgtmStackContainer;
2020

21+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
2122
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2223
import org.springframework.boot.testcontainers.service.connection.ContainerConnectionDetailsFactory;
2324
import org.springframework.boot.testcontainers.service.connection.ContainerConnectionSource;
@@ -52,8 +53,12 @@ private OpenTelemetryTracingContainerConnectionDetails(ContainerConnectionSource
5253
}
5354

5455
@Override
55-
public String getUrl() {
56-
return "%s/v1/traces".formatted(getContainer().getOtlpHttpUrl());
56+
public String getUrl(Transport transport) {
57+
String url = switch (transport) {
58+
case HTTP -> getContainer().getOtlpHttpUrl();
59+
case GRPC -> getContainer().getOtlpGrpcUrl();
60+
};
61+
return "%s/v1/traces".formatted(url);
5762
}
5863

5964
}

spring-boot-project/spring-boot-testcontainers/src/main/java/org/springframework/boot/testcontainers/service/connection/otlp/OpenTelemetryTracingContainerConnectionDetailsFactory.java

Lines changed: 12 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2012-2023 the original author or authors.
2+
* Copyright 2012-2024 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -19,6 +19,7 @@
1919
import org.testcontainers.containers.Container;
2020
import org.testcontainers.containers.GenericContainer;
2121

22+
import org.springframework.boot.actuate.autoconfigure.opentelemetry.otlp.Transport;
2223
import org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpTracingConnectionDetails;
2324
import org.springframework.boot.testcontainers.service.connection.ContainerConnectionDetailsFactory;
2425
import org.springframework.boot.testcontainers.service.connection.ContainerConnectionSource;
@@ -35,6 +36,10 @@
3536
class OpenTelemetryTracingContainerConnectionDetailsFactory
3637
extends ContainerConnectionDetailsFactory<Container<?>, OtlpTracingConnectionDetails> {
3738

39+
private static final int OTLP_GRPC_PORT = 4317;
40+
41+
private static final int OTLP_HTTP_PORT = 4318;
42+
3843
OpenTelemetryTracingContainerConnectionDetailsFactory() {
3944
super("otel/opentelemetry-collector-contrib",
4045
"org.springframework.boot.actuate.autoconfigure.tracing.otlp.OtlpAutoConfiguration");
@@ -54,8 +59,12 @@ private OpenTelemetryTracingContainerConnectionDetails(ContainerConnectionSource
5459
}
5560

5661
@Override
57-
public String getUrl() {
58-
return "http://%s:%d/v1/traces".formatted(getContainer().getHost(), getContainer().getMappedPort(4318));
62+
public String getUrl(Transport transport) {
63+
int port = switch (transport) {
64+
case HTTP -> OTLP_HTTP_PORT;
65+
case GRPC -> OTLP_GRPC_PORT;
66+
};
67+
return "http://%s:%d/v1/traces".formatted(getContainer().getHost(), getContainer().getMappedPort(port));
5968
}
6069

6170
}

0 commit comments

Comments
 (0)