-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Do not skip service/operation indexing for firehose spans + a couple fixes #2090
Do not skip service/operation indexing for firehose spans + a couple fixes #2090
Conversation
|
||
func (s *SpanWriter) writeOtherIndexes(span *model.Span, ds *dbmodel.Span) error { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you use a more descriptive name here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
like what?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps this could just be writeIndexes
like earlier, but it calls writeServiceOperationIndex
? Might simplify the branching in writer.go
as well.
assert.Equal(t, "planet-express", serviceWritten.Load()) | ||
assert.Equal(t, dbmodel.Operation{ | ||
ServiceName: "planet-express", | ||
SpanKind: "", | ||
OperationName: "package-delivery", | ||
}, operationWritten.Load()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are these not tested elsewhere? For e.g., if plugin/storage/cassandra/spanstore/writer.go L183 were removed - wouldn't other tests fail?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not testing whether index writing works, but whether it's invoked for firehose span. This is the only test that makes distinction between two types of indices.
Codecov Report
@@ Coverage Diff @@
## master #2090 +/- ##
=========================================
+ Coverage 96.29% 96.3% +<.01%
=========================================
Files 214 214
Lines 10540 10542 +2
=========================================
+ Hits 10150 10152 +2
+ Misses 331 330 -1
- Partials 59 60 +1
Continue to review full report at Codecov.
|
Signed-off-by: Yuri Shkuro <[email protected]>
Signed-off-by: Yuri Shkuro <[email protected]>
49f08d1
to
19369d0
Compare
Signed-off-by: Yuri Shkuro <[email protected]>
…ymore. which cqlsh prints /opt/cassandra/bin/cqlsh Signed-off-by: Yuri Shkuro <[email protected]>
Signed-off-by: Yuri Shkuro <[email protected]>
Signed-off-by: Yuri Shkuro <[email protected]>
break | ||
} | ||
time.Sleep(500 * time.Microsecond) | ||
} | ||
tr.mb.AssertGaugeMetrics(t, | ||
metricstest.ExpectedMetric{Name: "client_stats.connected_clients", Value: test.expGauge}) | ||
assert.EqualValues(t, test.expGauge, gaugeValue) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unrelated change to fix a flaky test. There was a race condition with gauge value being 1 inside the loop and then dropping back to 0 by the time the AssertGaugeMetrics was called.
@@ -3,7 +3,7 @@ | |||
# This script is used in the Docker image jaegertracing/jaeger-cassandra-schema | |||
# that allows installing Jaeger keyspace and schema without installing cqlsh. | |||
|
|||
CQLSH=${CQLSH:-"/usr/bin/cqlsh"} | |||
CQLSH=${CQLSH:-"/opt/cassandra/bin/cqlsh"} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
unrelated change to fix regression in Cassandra tests that were breaking CI.
Which problem is this PR solving?
The transitive dep graphs view uses service & operation index to populate the dropdown. However, when traces are stored in the firehose mode, they are excluded from indexing (to reduce the load on storage), including the service/operation tables, which are actually very inexpensive to write because writes only happen once per 12hr period due to a cache in front of them.
Short description of the changes
Allow service/operation tables to be written even in firehose mode.