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

feat: messenger improve latency #108

Merged
merged 36 commits into from
Nov 11, 2024
Merged
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
56f4a88
feat: add timing to state transitions in messenger
gk-kindred Oct 8, 2024
034485c
chore: make tokio select biased for inbound service
gk-kindred Oct 11, 2024
e43eb6c
chore: inbound service, process next actions even in candidate messag…
gk-kindred Oct 11, 2024
b40017e
chore: flip the arms in biased tokio::select for inbound service
gk-kindred Oct 18, 2024
544fe9c
chore: make arm for feedback to run only if there is Some feedback
gk-kindred Oct 21, 2024
e264eb2
chore: use talos version - biased arms flipped - print time spend in …
gk-kindred Oct 21, 2024
163e24e
chore: remove tokio::select and use mpsc channel try_recv
gk-kindred Oct 21, 2024
9a87c85
chore: comment out the printing of stats in inbound service for try_r…
gk-kindred Oct 21, 2024
b79569f
chore: remove the pruning and commit check for every feedback
gk-kindred Oct 21, 2024
d2af214
chore: use tokio select without biased and print useful metrics
gk-kindred Oct 22, 2024
a6ceff4
chore: optimize suffix operations - getting items to process and upda…
gk-kindred Oct 22, 2024
407b3d9
chore: reduce the prune_start_threshold
gk-kindred Oct 23, 2024
eb14fd3
chore: commit and prune logic kicks in after 10_000 completed actions
gk-kindred Oct 23, 2024
826ca48
chore: commit and prune logic kicks in when prune_index is above the …
gk-kindred Oct 23, 2024
91b9efe
chore: call process_next_actions in 10ms interval
gk-kindred Oct 23, 2024
e9fab0a
chore: reduce the interval to 5ms
gk-kindred Oct 23, 2024
004523f
chore: use take_while to update prune_index
gk-kindred Oct 28, 2024
05b62a9
chore: clean up
gk-kindred Nov 1, 2024
7708385
chore: pass topic creation configs to create topic bin
gk-kindred Nov 1, 2024
da92edf
chore: print topic configs passed to create_topic
gk-kindred Nov 3, 2024
100f869
chore: print time taken between publish and receive acks
gk-kindred Nov 4, 2024
8a5cb34
chore: print time taken for building the list of actions to process
gk-kindred Nov 6, 2024
c1b1f94
chore: update prune index at the end of processing next actions
gk-kindred Nov 6, 2024
ceac5b0
chore: print the timing from decision create to on_commit publish
gk-kindred Nov 6, 2024
4dcecb6
chore: print timestamps
gk-kindred Nov 6, 2024
b47f123
chore: update prune index only when completed
gk-kindred Nov 7, 2024
10d0886
chore: comment printing messages
gk-kindred Nov 7, 2024
d1ca56c
chore: final refactoring - part 1
gk-kindred Nov 11, 2024
3f46a8a
chore: final refactoring - part 2
gk-kindred Nov 11, 2024
f5461be
chore: prune check and commit more frequently
gk-kindred Nov 11, 2024
5e0cb0b
chore: reduce commit frequency but do prune check often
gk-kindred Nov 11, 2024
38496b7
chore: introduce config for inbound service and commit based on the c…
gk-kindred Nov 11, 2024
111b266
chore: set the commit_size to 2000
gk-kindred Nov 11, 2024
518a4a7
chore: prune logic only when above the threshold
gk-kindred Nov 11, 2024
88ca2cc
chore: update the default commit_size to 5K records
gk-kindred Nov 11, 2024
67140e1
chore: updates from review comments
gk-kindred Nov 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: make arm for feedback to run only if there is Some feedback
gk-kindred committed Oct 21, 2024
commit 544fe9c7bcc32a9e1a11a41545820124a1c56ac2
15 changes: 9 additions & 6 deletions packages/talos_messenger_core/src/services/inbound_service.rs
Original file line number Diff line number Diff line change
@@ -164,22 +164,22 @@ where
tokio::select! {
biased;
// Receive feedback from publisher.
feedback_result = self.rx_feedback_channel.recv() => {
Some(feedback_result) = self.rx_feedback_channel.recv() => {
on_commit_actions_feedback_count = on_commit_actions_feedback_count + 1;
// log::warn!("Counts.... candidate_message_count={candidate_message_count} | decision_message_count={decision_message_count} | on_commit_actions_feedback_count={on_commit_actions_feedback_count}");
match feedback_result {
Some(MessengerChannelFeedback::Error(version, key, message_error)) => {
MessengerChannelFeedback::Error(version, key, message_error) => {
error!("Failed to process version={version} with error={message_error:?}");
self.handle_action_failed(version, &key);

},
Some(MessengerChannelFeedback::Success(version, key)) => {
MessengerChannelFeedback::Success(version, key) => {
info!("Successfully processed version={version} with action_key={key}");
Copy link
Contributor

Choose a reason for hiding this comment

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

Should it be debug instead of info, to reduce a noise in the log?

self.handle_action_success(version, &key);
},
None => {
debug!("No feedback message to process..");
}
// None => {
// debug!("No feedback message to process..");
// }
}
// Process the next items with commit actions
self.process_next_actions().await?
@@ -250,6 +250,9 @@ where
},
}
}
else => {
warn!("Unhandled arm....");
}

}
}