Skip to content
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

Kafka time stamp fix #5108

Merged
merged 1 commit into from
Oct 31, 2024
Merged

Conversation

kkondaka
Copy link
Collaborator

Description

Pipeline latency is showing up as negative value some times. This fix makes sure that the time received from Kafka consumer record is valid. If it's not valid, it is replaced with last valid value. If last valid value is not present, current time is used.

Issues Resolved

Resolves #[Issue number to be closed when this PR is merged]

Check List

  • New functionality includes testing.
  • New functionality has a documentation issue. Please link to it in this PR.
    • New functionality has javadoc added
  • [X ] Commits are signed with a real name per the DCO

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.

@@ -99,6 +99,7 @@ public class KafkaCustomConsumer implements Runnable, ConsumerRebalanceListener
private final LogRateLimiter errLogRateLimiter;
private final ByteDecoder byteDecoder;
private final long maxRetriesOnException;
private final Map<Integer, Long> lastReceivedTimeStampMap;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
private final Map<Integer, Long> lastReceivedTimeStampMap;
private final Map<Integer, Long> partitionToLastReceivedTimestampMillis;

Clarifies how we index and that we are storing millis here.

@@ -142,6 +144,23 @@ KafkaTopicConsumerMetrics getTopicMetrics() {
return topicMetrics;
}

private <T> long getReceivedTime(final ConsumerRecord<String, T> consumerRecord) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need some unit testing on this logic.

Also, you could make a class that handles this and it would be easier to verify. But, I'll leave that to you.

class PartitionTracker {
  <T> Instant getReceivedTime(final ConsumerRecord<String, T> consumerRecord) {
    // same logic
  }
}

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will add unit tests but adding a class seems to be little bit too much. Also, we use "PartitionTracker" for tracking the acks at partition level.

Signed-off-by: Krishna Kondaka <[email protected]>
@kkondaka kkondaka force-pushed the kafka-time-stamp-fix branch from d0cc522 to 35a168a Compare October 30, 2024 04:02
@kkondaka kkondaka merged commit 5108528 into opensearch-project:main Oct 31, 2024
48 of 50 checks passed
san81 added a commit to san81/data-prepper that referenced this pull request Nov 2, 2024
# This is the 1st commit message:

additional test coverage

Signed-off-by: Santhosh Gandhe <[email protected]>

# This is the commit message #2:

cleaned up JiraOauthConfig file

Signed-off-by: Santhosh Gandhe <[email protected]>

# This is the commit message #3:

addressing review comments and simplifying the exception handling

Signed-off-by: Santhosh Gandhe <[email protected]>

# This is the commit message #4:

Add external origination time for events created from S3 Object (opensearch-project#5104)

Signed-off-by: Krishna Kondaka <[email protected]>
Co-authored-by: Krishna Kondaka <[email protected]>
# This is the commit message #5:

moved the wait block out of the catch block

Signed-off-by: Santhosh Gandhe <[email protected]>

# This is the commit message #6:

Renewal logic adjusted

Signed-off-by: Santhosh Gandhe <[email protected]>

# This is the commit message #7:

partial

Signed-off-by: Maxwell Brown <[email protected]>

fix merge issues

Signed-off-by: Maxwell Brown <[email protected]>

update

Signed-off-by: Maxwell Brown <[email protected]>

Add getColumnDataTypes method to SchemaManager to get datatype for table columns (opensearch-project#5135)

Add getColumnDataTypes method to SchemaManager

Signed-off-by: Dinu John <[email protected]>

Add model for table column metadata for Global state (opensearch-project#5136)

Signed-off-by: Dinu John <[email protected]>

Rename the KDS source plugin name to "kinesis-data-streams" (opensearch-project#5138)

Signed-off-by: Souvik Bose <[email protected]>
Co-authored-by: Souvik Bose <[email protected]>

Addressed review comments (opensearch-project#5108)

Signed-off-by: Krishna Kondaka <[email protected]>

fixes related to source config properties change

Signed-off-by: Santhosh Gandhe <[email protected]>

removed future handling for loop based operations

Signed-off-by: Santhosh Gandhe <[email protected]>

additional test cases

Signed-off-by: Santhosh Gandhe <[email protected]>

addressing review comments

Signed-off-by: Santhosh Gandhe <[email protected]>

Jira Service Test coverage

Signed-off-by: Maxwell Brown <[email protected]>

jirasourceconfigTest comments

Signed-off-by: Maxwell Brown <[email protected]>

introduced RestClient and moved rest template interactions to there. Similar chage on the test cases too

Signed-off-by: Santhosh Gandhe <[email protected]>

backingoff for any kind of exception.

Signed-off-by: Santhosh Gandhe <[email protected]>

restructured constants file

Signed-off-by: Santhosh Gandhe <[email protected]>

JiraSourceTests

Signed-off-by: Maxwell Brown <[email protected]>

JiraItemInfo coverage

Signed-off-by: Maxwell Brown <[email protected]>

jira service branch coverage

Signed-off-by: Maxwell Brown <[email protected]>

branch coverage jira service

Signed-off-by: Maxwell Brown <[email protected]>

move add Items to queue logic into JiraItemInfo

Signed-off-by: Maxwell Brown <[email protected]>

fixing regex and adding date time formatter

Signed-off-by: Maxwell Brown <[email protected]>

Revert "Jira source"

re add changes and fix issues

Signed-off-by: Maxwell Brown <[email protected]>

unneeded comment

Signed-off-by: Maxwell Brown <[email protected]>

using issue bean methods to simplify the logic

Signed-off-by: Santhosh Gandhe <[email protected]>
san81 pushed a commit to san81/data-prepper that referenced this pull request Nov 3, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants