Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/gradle/plugins/repository-gcs/com…
Browse files Browse the repository at this point in the history
….google.api.grpc-proto-google-common-protos-2.25.0

Signed-off-by: Andriy Redko <[email protected]>
  • Loading branch information
reta authored Sep 25, 2023
2 parents 3f3f84c + 19fa37c commit ef269e8
Show file tree
Hide file tree
Showing 26 changed files with 510 additions and 258 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/gradle-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ jobs:
- name: Upload Coverage Report
if: success()
uses: codecov/codecov-action@v2
uses: codecov/codecov-action@v3
with:
files: ./codeCoverage.xml

Expand Down
5 changes: 4 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -101,13 +101,15 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
- Bump `com.google.http-client:google-http-client-jackson2` from 1.43.2 to 1.43.3 ([#10126](https://github.com/opensearch-project/OpenSearch/pull/10126))
- Bump `org.xerial.snappy:snappy-java` from 1.1.10.3 to 1.1.10.4 ([#10206](https://github.com/opensearch-project/OpenSearch/pull/10206))
- Bump `com.google.api.grpc:proto-google-common-protos` from 2.10.0 to 2.25.0 ([#10208](https://github.com/opensearch-project/OpenSearch/pull/10208))
- Bump `codecov/codecov-action` from 2 to 3 ([#10209](https://github.com/opensearch-project/OpenSearch/pull/10209))

### Changed
- Add instrumentation in rest and network layer. ([#9415](https://github.com/opensearch-project/OpenSearch/pull/9415))
- Allow parameterization of tests with OpenSearchIntegTestCase.SuiteScopeTestCase annotation ([#9916](https://github.com/opensearch-project/OpenSearch/pull/9916))
- Mute the query profile IT with concurrent execution ([#9840](https://github.com/opensearch-project/OpenSearch/pull/9840))
- Force merge with `only_expunge_deletes` honors max segment size ([#10036](https://github.com/opensearch-project/OpenSearch/pull/10036))
- Add instrumentation in transport service. ([#10042](https://github.com/opensearch-project/OpenSearch/pull/10042))
- [Tracing Framework] Add support for SpanKind. ([#10122](https://github.com/opensearch-project/OpenSearch/pull/10122))

### Deprecated

Expand All @@ -117,8 +119,9 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
- Fix ignore_missing parameter has no effect when using template snippet in rename ingest processor ([#9725](https://github.com/opensearch-project/OpenSearch/pull/9725))
- Fix broken backward compatibility from 2.7 for IndexSorted field indices ([#10045](https://github.com/opensearch-project/OpenSearch/pull/10045))
- Fix concurrent search NPE when track_total_hits, terminate_after and size=0 are used ([#10082](https://github.com/opensearch-project/OpenSearch/pull/10082))
- Fix remove ingest processor handing ignore_missing parameter not correctly ([10089](https://github.com/opensearch-project/OpenSearch/pull/10089))

### Security

[Unreleased 3.0]: https://github.com/opensearch-project/OpenSearch/compare/2.x...HEAD
[Unreleased 2.x]: https://github.com/opensearch-project/OpenSearch/compare/2.11...2.x
[Unreleased 2.x]: https://github.com/opensearch-project/OpenSearch/compare/2.11...2.x
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
package org.opensearch.telemetry.tracing;

import org.opensearch.common.annotation.InternalApi;
import org.opensearch.telemetry.tracing.attributes.Attributes;

import java.io.Closeable;
import java.io.IOException;
Expand Down Expand Up @@ -44,27 +43,13 @@ public DefaultTracer(TracingTelemetry tracingTelemetry, TracerContextStorage<Str

@Override
public Span startSpan(SpanCreationContext context) {
return startSpan(context.getSpanName(), context.getAttributes());
}

@Override
public Span startSpan(String spanName) {
return startSpan(spanName, Attributes.EMPTY);
}

@Override
public Span startSpan(String spanName, Attributes attributes) {
return startSpan(spanName, (SpanContext) null, attributes);
}

@Override
public Span startSpan(String spanName, SpanContext parentSpan, Attributes attributes) {
Span span = null;
if (parentSpan != null) {
span = createSpan(spanName, parentSpan.getSpan(), attributes);
Span parentSpan = null;
if (context.getParent() != null) {
parentSpan = context.getParent().getSpan();
} else {
span = createSpan(spanName, getCurrentSpanInternal(), attributes);
parentSpan = getCurrentSpanInternal();
}
Span span = createSpan(context, parentSpan);
setCurrentSpanInContext(span);
addDefaultAttributes(span);
return span;
Expand All @@ -87,12 +72,7 @@ public SpanContext getCurrentSpan() {

@Override
public ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext) {
return startScopedSpan(spanCreationContext, null);
}

@Override
public ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext, SpanContext parentSpan) {
Span span = startSpan(spanCreationContext.getSpanName(), parentSpan, spanCreationContext.getAttributes());
Span span = startSpan(spanCreationContext);
SpanScope spanScope = withSpanInScope(span);
return new DefaultScopedSpan(span, spanScope);
}
Expand All @@ -102,8 +82,8 @@ public SpanScope withSpanInScope(Span span) {
return DefaultSpanScope.create(span, tracerContextStorage).attach();
}

private Span createSpan(String spanName, Span parentSpan, Attributes attributes) {
return tracingTelemetry.createSpan(spanName, parentSpan, attributes);
private Span createSpan(SpanCreationContext spanCreationContext, Span parentSpan) {
return tracingTelemetry.createSpan(spanCreationContext, parentSpan);
}

private void setCurrentSpanInContext(Span span) {
Expand All @@ -121,11 +101,7 @@ protected void addDefaultAttributes(Span span) {
@Override
public Span startSpan(SpanCreationContext spanCreationContext, Map<String, List<String>> headers) {
Optional<Span> propagatedSpan = tracingTelemetry.getContextPropagator().extractFromHeaders(headers);
return startSpan(
spanCreationContext.getSpanName(),
propagatedSpan.map(SpanContext::new).orElse(null),
spanCreationContext.getAttributes()
);
return startSpan(spanCreationContext.parent(propagatedSpan.map(SpanContext::new).orElse(null)));
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,74 @@
*/
@ExperimentalApi
public final class SpanCreationContext {
private final String spanName;
private final Attributes attributes;
private String spanName;
private Attributes attributes;
private SpanKind spanKind = SpanKind.INTERNAL;
private SpanContext parent;

/**
* Constructor.
*/
private SpanCreationContext() {}

/**
* Sets the span type to server.
* @return spanCreationContext
*/
public static SpanCreationContext server() {
SpanCreationContext spanCreationContext = new SpanCreationContext();
spanCreationContext.spanKind = SpanKind.SERVER;
return spanCreationContext;
}

/**
* Sets the span type to client.
* @return spanCreationContext
*/
public static SpanCreationContext client() {
SpanCreationContext spanCreationContext = new SpanCreationContext();
spanCreationContext.spanKind = SpanKind.CLIENT;
return spanCreationContext;
}

/**
* Sets the span type to internal.
* @return spanCreationContext
*/
public static SpanCreationContext internal() {
SpanCreationContext spanCreationContext = new SpanCreationContext();
spanCreationContext.spanKind = SpanKind.INTERNAL;
return spanCreationContext;
}

/**
* Sets the span name.
* @param spanName span name.
* @param attributes attributes.
* @return spanCreationContext
*/
public SpanCreationContext(String spanName, Attributes attributes) {
public SpanCreationContext name(String spanName) {
this.spanName = spanName;
return this;
}

/**
* Sets the span attributes.
* @param attributes attributes.
* @return spanCreationContext
*/
public SpanCreationContext attributes(Attributes attributes) {
this.attributes = attributes;
return this;
}

/**
* Sets the parent for spann
* @param parent parent
* @return spanCreationContext
*/
public SpanCreationContext parent(SpanContext parent) {
this.parent = parent;
return this;
}

/**
Expand All @@ -46,4 +103,20 @@ public String getSpanName() {
public Attributes getAttributes() {
return attributes;
}

/**
* Returns the span kind.
* @return spankind.
*/
public SpanKind getSpanKind() {
return spanKind;
}

/**
* Returns the parent span
* @return parent.
*/
public SpanContext getParent() {
return parent;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/*
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*/

package org.opensearch.telemetry.tracing;

import org.opensearch.common.annotation.PublicApi;

/**
* Type of Span.
*/
@PublicApi(since = "2.11.0")
public enum SpanKind {
/**
* Span represents the client side code.
*/
CLIENT,
/**
* Span represents the server side code.
*/
SERVER,

/**
* Span represents the internal calls. This is the default value of a span type.
*/
INTERNAL;
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
package org.opensearch.telemetry.tracing;

import org.opensearch.common.annotation.ExperimentalApi;
import org.opensearch.telemetry.tracing.attributes.Attributes;
import org.opensearch.telemetry.tracing.http.HttpTracer;

import java.io.Closeable;
Expand All @@ -32,34 +31,6 @@ public interface Tracer extends HttpTracer, Closeable {
*/
Span startSpan(SpanCreationContext context);

/**
* Starts the {@link Span} with given name
*
* @param spanName span name
* @return span, must be closed.
*/
Span startSpan(String spanName);

/**
* Starts the {@link Span} with given name and attributes. This is required in cases when some attribute based
* decision needs to be made before starting the span. Very useful in the case of Sampling.
*
* @param spanName span name.
* @param attributes attributes to be added.
* @return span, must be closed.
*/
Span startSpan(String spanName, Attributes attributes);

/**
* Starts the {@link Span} with the given name, parent and attributes.
*
* @param spanName span name.
* @param parentSpan parent span.
* @param attributes attributes to be added.
* @return span, must be closed.
*/
Span startSpan(String spanName, SpanContext parentSpan, Attributes attributes);

/**
* Returns the current span.
* @return current wrapped span.
Expand All @@ -74,15 +45,6 @@ public interface Tracer extends HttpTracer, Closeable {
*/
ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext);

/**
* Start the span and scoped it. This must be used for scenarios where {@link SpanScope} and {@link Span} lifecycles
* are same and ends within the same thread where created.
* @param spanCreationContext span creation context
* @param parentSpan parent span.
* @return scope of the span, must be closed with explicit close or with try-with-resource
*/
ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext, SpanContext parentSpan);

/**
* Creates the Span Scope for a current thread. It's mandatory to scope the span just after creation so that it will
* automatically manage the attach /detach to the current thread.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
package org.opensearch.telemetry.tracing;

import org.opensearch.common.annotation.ExperimentalApi;
import org.opensearch.telemetry.tracing.attributes.Attributes;

import java.io.Closeable;

Expand All @@ -24,12 +23,11 @@ public interface TracingTelemetry extends Closeable {
/**
* Creates span with provided arguments
*
* @param spanName name of the span
* @param parentSpan span's parent span
* @param attributes attributes to be added.
* @param spanCreationContext span creation context.
* @param parentSpan parent span.
* @return span instance
*/
Span createSpan(String spanName, Span parentSpan, Attributes attributes);
Span createSpan(SpanCreationContext spanCreationContext, Span parentSpan);

/**
* provides tracing context propagator
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
import org.opensearch.telemetry.tracing.SpanCreationContext;
import org.opensearch.telemetry.tracing.SpanScope;
import org.opensearch.telemetry.tracing.Tracer;
import org.opensearch.telemetry.tracing.attributes.Attributes;

import java.util.List;
import java.util.Map;
Expand All @@ -40,21 +39,6 @@ public Span startSpan(SpanCreationContext context) {
return NoopSpan.INSTANCE;
}

@Override
public Span startSpan(String spanName) {
return NoopSpan.INSTANCE;
}

@Override
public Span startSpan(String spanName, Attributes attributes) {
return NoopSpan.INSTANCE;
}

@Override
public Span startSpan(String spanName, SpanContext parentSpan, Attributes attributes) {
return NoopSpan.INSTANCE;
}

@Override
public SpanContext getCurrentSpan() {
return new SpanContext(NoopSpan.INSTANCE);
Expand All @@ -65,11 +49,6 @@ public ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext) {
return ScopedSpan.NO_OP;
}

@Override
public ScopedSpan startScopedSpan(SpanCreationContext spanCreationContext, SpanContext parentSpan) {
return ScopedSpan.NO_OP;
}

@Override
public SpanScope withSpanInScope(Span span) {
return SpanScope.NO_OP;
Expand Down
Loading

0 comments on commit ef269e8

Please sign in to comment.