Add support for DD_TRACE_AGENT_PORT setting

Makes this more consistent with other apm language clients.
This commit is contained in:
Tyler Benson 2018-11-16 10:54:27 -08:00
parent 7d0aa4693e
commit 93c046a664
5 changed files with 69 additions and 18 deletions

View File

@ -31,7 +31,8 @@ public class Config {
public static final String SERVICE_NAME = "service.name"; public static final String SERVICE_NAME = "service.name";
public static final String WRITER_TYPE = "writer.type"; public static final String WRITER_TYPE = "writer.type";
public static final String AGENT_HOST = "agent.host"; public static final String AGENT_HOST = "agent.host";
public static final String AGENT_PORT = "agent.port"; public static final String TRACE_AGENT_PORT = "trace.agent.port";
public static final String AGENT_PORT_LEGACY = "agent.port";
public static final String PRIORITY_SAMPLING = "priority.sampling"; public static final String PRIORITY_SAMPLING = "priority.sampling";
public static final String TRACE_RESOLVER_ENABLED = "trace.resolver.enabled"; public static final String TRACE_RESOLVER_ENABLED = "trace.resolver.enabled";
public static final String SERVICE_MAPPING = "service.mapping"; public static final String SERVICE_MAPPING = "service.mapping";
@ -54,7 +55,7 @@ public class Config {
public static final String DEFAULT_AGENT_WRITER_TYPE = DD_AGENT_WRITER_TYPE; public static final String DEFAULT_AGENT_WRITER_TYPE = DD_AGENT_WRITER_TYPE;
public static final String DEFAULT_AGENT_HOST = "localhost"; public static final String DEFAULT_AGENT_HOST = "localhost";
public static final int DEFAULT_AGENT_PORT = 8126; public static final int DEFAULT_TRACE_AGENT_PORT = 8126;
private static final boolean DEFAULT_PRIORITY_SAMPLING_ENABLED = false; private static final boolean DEFAULT_PRIORITY_SAMPLING_ENABLED = false;
private static final boolean DEFAULT_TRACE_RESOLVER_ENABLED = true; private static final boolean DEFAULT_TRACE_RESOLVER_ENABLED = true;
@ -94,7 +95,10 @@ public class Config {
serviceName = getSettingFromEnvironment(SERVICE_NAME, DEFAULT_SERVICE_NAME); serviceName = getSettingFromEnvironment(SERVICE_NAME, DEFAULT_SERVICE_NAME);
writerType = getSettingFromEnvironment(WRITER_TYPE, DEFAULT_AGENT_WRITER_TYPE); writerType = getSettingFromEnvironment(WRITER_TYPE, DEFAULT_AGENT_WRITER_TYPE);
agentHost = getSettingFromEnvironment(AGENT_HOST, DEFAULT_AGENT_HOST); agentHost = getSettingFromEnvironment(AGENT_HOST, DEFAULT_AGENT_HOST);
agentPort = getIntegerSettingFromEnvironment(AGENT_PORT, DEFAULT_AGENT_PORT); agentPort =
getIntegerSettingFromEnvironment(
TRACE_AGENT_PORT,
getIntegerSettingFromEnvironment(AGENT_PORT_LEGACY, DEFAULT_TRACE_AGENT_PORT));
prioritySamplingEnabled = prioritySamplingEnabled =
getBooleanSettingFromEnvironment(PRIORITY_SAMPLING, DEFAULT_PRIORITY_SAMPLING_ENABLED); getBooleanSettingFromEnvironment(PRIORITY_SAMPLING, DEFAULT_PRIORITY_SAMPLING_ENABLED);
traceResolverEnabled = traceResolverEnabled =
@ -124,7 +128,11 @@ public class Config {
serviceName = properties.getProperty(SERVICE_NAME, parent.serviceName); serviceName = properties.getProperty(SERVICE_NAME, parent.serviceName);
writerType = properties.getProperty(WRITER_TYPE, parent.writerType); writerType = properties.getProperty(WRITER_TYPE, parent.writerType);
agentHost = properties.getProperty(AGENT_HOST, parent.agentHost); agentHost = properties.getProperty(AGENT_HOST, parent.agentHost);
agentPort = getPropertyIntegerValue(properties, AGENT_PORT, parent.agentPort); agentPort =
getPropertyIntegerValue(
properties,
TRACE_AGENT_PORT,
getPropertyIntegerValue(properties, AGENT_PORT_LEGACY, parent.agentPort));
prioritySamplingEnabled = prioritySamplingEnabled =
getPropertyBooleanValue(properties, PRIORITY_SAMPLING, parent.prioritySamplingEnabled); getPropertyBooleanValue(properties, PRIORITY_SAMPLING, parent.prioritySamplingEnabled);
traceResolverEnabled = traceResolverEnabled =

View File

@ -19,6 +19,8 @@ class ConfigTest extends Specification {
private static final DD_SPAN_TAGS_ENV = "DD_SPAN_TAGS" private static final DD_SPAN_TAGS_ENV = "DD_SPAN_TAGS"
private static final DD_HEADER_TAGS_ENV = "DD_HEADER_TAGS" private static final DD_HEADER_TAGS_ENV = "DD_HEADER_TAGS"
private static final DD_JMXFETCH_METRICS_CONFIGS_ENV = "DD_JMXFETCH_METRICS_CONFIGS" private static final DD_JMXFETCH_METRICS_CONFIGS_ENV = "DD_JMXFETCH_METRICS_CONFIGS"
private static final DD_TRACE_AGENT_PORT_ENV = "DD_TRACE_AGENT_PORT"
private static final DD_AGENT_PORT_LEGACY_ENV = "DD_AGENT_PORT"
def "verify defaults"() { def "verify defaults"() {
when: when:
@ -49,7 +51,8 @@ class ConfigTest extends Specification {
System.setProperty(PREFIX + SERVICE_NAME, "something else") System.setProperty(PREFIX + SERVICE_NAME, "something else")
System.setProperty(PREFIX + WRITER_TYPE, "LoggingWriter") System.setProperty(PREFIX + WRITER_TYPE, "LoggingWriter")
System.setProperty(PREFIX + AGENT_HOST, "somehost") System.setProperty(PREFIX + AGENT_HOST, "somehost")
System.setProperty(PREFIX + AGENT_PORT, "123") System.setProperty(PREFIX + TRACE_AGENT_PORT, "123")
System.setProperty(PREFIX + AGENT_PORT_LEGACY, "456")
System.setProperty(PREFIX + PRIORITY_SAMPLING, "true") System.setProperty(PREFIX + PRIORITY_SAMPLING, "true")
System.setProperty(PREFIX + TRACE_RESOLVER_ENABLED, "false") System.setProperty(PREFIX + TRACE_RESOLVER_ENABLED, "false")
System.setProperty(PREFIX + SERVICE_MAPPING, "a:1") System.setProperty(PREFIX + SERVICE_MAPPING, "a:1")
@ -92,6 +95,13 @@ class ConfigTest extends Specification {
environmentVariables.set(DD_WRITER_TYPE_ENV, "LoggingWriter") environmentVariables.set(DD_WRITER_TYPE_ENV, "LoggingWriter")
environmentVariables.set(DD_JMXFETCH_METRICS_CONFIGS_ENV, "some/file") environmentVariables.set(DD_JMXFETCH_METRICS_CONFIGS_ENV, "some/file")
if (overridePort) {
environmentVariables.set(DD_TRACE_AGENT_PORT_ENV, "123")
}
if (overrideLegacyPort) {
environmentVariables.set(DD_AGENT_PORT_LEGACY_ENV, "456")
}
when: when:
def config = new Config() def config = new Config()
@ -99,17 +109,33 @@ class ConfigTest extends Specification {
config.serviceName == "still something else" config.serviceName == "still something else"
config.writerType == "LoggingWriter" config.writerType == "LoggingWriter"
config.jmxFetchMetricsConfigs == ["some/file"] config.jmxFetchMetricsConfigs == ["some/file"]
config.agentPort == expectedPort
where:
overridePort | overrideLegacyPort | expectedPort
true | true | 123
true | false | 123
false | true | 456
false | false | 8126
} }
def "sys props override env vars"() { def "sys props override env vars"() {
setup: setup:
environmentVariables.set(DD_SERVICE_NAME_ENV, "still something else") environmentVariables.set(DD_SERVICE_NAME_ENV, "still something else")
environmentVariables.set(DD_WRITER_TYPE_ENV, "LoggingWriter") environmentVariables.set(DD_WRITER_TYPE_ENV, "LoggingWriter")
environmentVariables.set(DD_TRACE_AGENT_PORT_ENV, "777")
System.setProperty(PREFIX + SERVICE_NAME, "what we actually want") System.setProperty(PREFIX + SERVICE_NAME, "what we actually want")
System.setProperty(PREFIX + WRITER_TYPE, "DDAgentWriter") System.setProperty(PREFIX + WRITER_TYPE, "DDAgentWriter")
System.setProperty(PREFIX + AGENT_HOST, "somewhere") System.setProperty(PREFIX + AGENT_HOST, "somewhere")
System.setProperty(PREFIX + AGENT_PORT, "9999")
if (overridePort) {
System.setProperty(PREFIX + TRACE_AGENT_PORT, "123")
}
if (overrideLegacyPort) {
System.setProperty(PREFIX + AGENT_PORT_LEGACY, "456")
}
when: when:
def config = new Config() def config = new Config()
@ -118,7 +144,14 @@ class ConfigTest extends Specification {
config.serviceName == "what we actually want" config.serviceName == "what we actually want"
config.writerType == "DDAgentWriter" config.writerType == "DDAgentWriter"
config.agentHost == "somewhere" config.agentHost == "somewhere"
config.agentPort == 9999 config.agentPort == expectedPort
where:
overridePort | overrideLegacyPort | expectedPort
true | true | 123
true | false | 123
false | true | 777 // env var gets picked up instead.
false | false | 777 // env var gets picked up instead.
} }
def "sys props override properties"() { def "sys props override properties"() {
@ -127,7 +160,7 @@ class ConfigTest extends Specification {
properties.setProperty(SERVICE_NAME, "something else") properties.setProperty(SERVICE_NAME, "something else")
properties.setProperty(WRITER_TYPE, "LoggingWriter") properties.setProperty(WRITER_TYPE, "LoggingWriter")
properties.setProperty(AGENT_HOST, "somehost") properties.setProperty(AGENT_HOST, "somehost")
properties.setProperty(AGENT_PORT, "123") properties.setProperty(TRACE_AGENT_PORT, "123")
properties.setProperty(PRIORITY_SAMPLING, "true") properties.setProperty(PRIORITY_SAMPLING, "true")
properties.setProperty(TRACE_RESOLVER_ENABLED, "false") properties.setProperty(TRACE_RESOLVER_ENABLED, "false")
properties.setProperty(SERVICE_MAPPING, "a:1") properties.setProperty(SERVICE_MAPPING, "a:1")

View File

@ -1,7 +1,7 @@
package datadog.trace.common.writer; package datadog.trace.common.writer;
import static datadog.trace.api.Config.DEFAULT_AGENT_HOST; import static datadog.trace.api.Config.DEFAULT_AGENT_HOST;
import static datadog.trace.api.Config.DEFAULT_AGENT_PORT; import static datadog.trace.api.Config.DEFAULT_TRACE_AGENT_PORT;
import datadog.opentracing.DDSpan; import datadog.opentracing.DDSpan;
import java.util.List; import java.util.List;
@ -64,7 +64,7 @@ public class DDAgentWriter implements Writer {
private boolean queueFullReported = false; private boolean queueFullReported = false;
public DDAgentWriter() { public DDAgentWriter() {
this(new DDApi(DEFAULT_AGENT_HOST, DEFAULT_AGENT_PORT)); this(new DDApi(DEFAULT_AGENT_HOST, DEFAULT_TRACE_AGENT_PORT));
} }
public DDAgentWriter(final DDApi api) { public DDAgentWriter(final DDApi api) {

View File

@ -5,7 +5,6 @@ import datadog.trace.api.Config
import datadog.trace.common.sampling.AllSampler import datadog.trace.common.sampling.AllSampler
import datadog.trace.common.sampling.RateByServiceSampler import datadog.trace.common.sampling.RateByServiceSampler
import datadog.trace.common.writer.DDAgentWriter import datadog.trace.common.writer.DDAgentWriter
import datadog.trace.common.writer.DDApi
import datadog.trace.common.writer.ListWriter import datadog.trace.common.writer.ListWriter
import datadog.trace.common.writer.LoggingWriter import datadog.trace.common.writer.LoggingWriter
import org.junit.Rule import org.junit.Rule
@ -27,6 +26,16 @@ class DDTracerTest extends Specification {
@Rule @Rule
public final EnvironmentVariables environmentVariables = new EnvironmentVariables() public final EnvironmentVariables environmentVariables = new EnvironmentVariables()
def setupSpec() {
// assert that a trace agent isn't running locally as that messes up the test.
try {
(new Socket("localhost", 8126)).close()
throw new IllegalStateException("Trace Agent unexpectedly running locally.")
} catch (final ConnectException ioe) {
// trace agent is not running locally.
}
}
def "verify defaults on tracer"() { def "verify defaults on tracer"() {
when: when:
def tracer = new DDTracer() def tracer = new DDTracer()
@ -93,11 +102,12 @@ class DDTracerTest extends Specification {
where: where:
source | key | value | expected source | key | value | expected
"writer" | "default" | "default" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://localhost:8126/v0.3/traces } }" "writer" | "default" | "default" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://localhost:8126/v0.3/traces } }"
"writer" | "writer.type" | "LoggingWriter" | "LoggingWriter { }" "writer" | "writer.type" | "LoggingWriter" | "LoggingWriter { }"
"writer" | "agent.host" | "somethingelse" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://somethingelse:8126/v0.3/traces } }" "writer" | "agent.host" | "somethingelse" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://somethingelse:8126/v0.3/traces } }"
"writer" | "agent.port" | "9999" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://localhost:9999/v0.3/traces } }" "writer" | "agent.port" | "777" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://localhost:777/v0.3/traces } }"
"writer" | "trace.agent.port" | "9999" | "DDAgentWriter { api=DDApi { tracesEndpoint=http://localhost:9999/v0.3/traces } }"
} }
def "verify sampler/writer constructor"() { def "verify sampler/writer constructor"() {

View File

@ -12,7 +12,7 @@ import java.util.concurrent.TimeUnit
import java.util.concurrent.atomic.AtomicReference import java.util.concurrent.atomic.AtomicReference
import static datadog.trace.api.Config.DEFAULT_AGENT_HOST import static datadog.trace.api.Config.DEFAULT_AGENT_HOST
import static datadog.trace.api.Config.DEFAULT_AGENT_PORT import static datadog.trace.api.Config.DEFAULT_TRACE_AGENT_PORT
class DDApiIntegrationTest { class DDApiIntegrationTest {
static class DDApiIntegrationV4Test extends Specification { static class DDApiIntegrationV4Test extends Specification {
@ -33,7 +33,7 @@ class DDApiIntegrationTest {
new PendingTrace(TRACER, "1", [:]), new PendingTrace(TRACER, "1", [:]),
TRACER) TRACER)
def api = new DDApi(DEFAULT_AGENT_HOST, DEFAULT_AGENT_PORT, v4()) def api = new DDApi(DEFAULT_AGENT_HOST, DEFAULT_TRACE_AGENT_PORT, v4())
def endpoint = new AtomicReference<String>(null) def endpoint = new AtomicReference<String>(null)
def agentResponse = new AtomicReference<String>(null) def agentResponse = new AtomicReference<String>(null)