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

Reapply changes from reverted PR 3423 #4257

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

KirillLykov
Copy link

@KirillLykov KirillLykov commented Jan 3, 2025

This PR adds back changes from PR 3423 but this time with less API changes which allows to simplify backport to 2.1.

Problem

In order to be able to use new client code in the SendTransactionService (see #3444), I need to wrap network-related code with the new structure ConnectionCacheClient.

Summary of Changes

To extract network code into a new structure, I had to move some auxiliary code into separate files.
Beside of that, changes are pretty minimal and I deliberately haven't tried to optimize existing code to keep changes minimal. It just does almost exactly the same as the old one.

Copy link

mergify bot commented Jan 3, 2025

If this PR represents a change to the public RPC API:

  1. Make sure it includes a complementary update to rpc-client/ (example)
  2. Open a follow-up PR to update the JavaScript client @solana/web3.js (example)

Thank you for keeping the RPC clients in sync with the server API @KirillLykov.

@KirillLykov KirillLykov marked this pull request as ready for review January 9, 2025 21:02
@t-nelson
Copy link

t-nelson commented Jan 9, 2025

This PR adds back changes from PR 3423 but this time with less API changes which allows to simplify backport to 2.1.

Summary of Changes

can you edit the description to describe the pr in its own terms rather than in reference to a previous one? i don't want to have to go guess at the intended differences in 900 lines of changes

Comment on lines 139 to 143
pub const LEADER_INFO_REFRESH_RATE_MS: u64 = 1000;

/// A struct responsible for holding up-to-date leader information
/// used for sending transactions.
pub struct CurrentLeaderInfo<T>
Copy link

Choose a reason for hiding this comment

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

this and any other moved public interface needs to be reexported here, with deprecation annotations. even though the annotations don't actually work on re-exports, they give us documentation and something to grep for

Copy link
Author

Choose a reason for hiding this comment

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

Done, added reexport of the public structures/const that have been moved.

Choose a reason for hiding this comment

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

thanks! can you annotate with the rust attribute instead of a comment?

@t-nelson
Copy link

t-nelson commented Jan 9, 2025

ideally this would be at least two PRs (i can't tell if more). first should exclusively re-organize the existing symbols in code, second(+) introduce new or changed logic. it is far too easy to miss logical changes in moved code

@KirillLykov
Copy link
Author

KirillLykov commented Jan 10, 2025

ideally this would be at least two PRs (i can't tell if more). first should exclusively re-organize the existing symbols in code, second(+) introduce new or changed logic. it is far too easy to miss logical changes in moved code

This PR only moves these structures and makes a couple of small changes in the way config is passed. Hence, accumulates some cosmetic changes that simplify further logic modifications. It has been reviewed by other people, so I believe it is safe enough in terms of the logic and the only problem is API modification. This PR is already a first of the chain of 4 PRs that only make any difference all together, splitting them into smaller atomic peaces would make it harder to maintain this PR chain, rebasing etc.

@KirillLykov KirillLykov added the v2.1 Backport to v2.1 branch label Jan 10, 2025
Copy link

mergify bot commented Jan 10, 2025

Backports to the beta branch are to be avoided unless absolutely necessary for fixing bugs, security issues, and perf regressions. Changes intended for backport should be structured such that a minimum effective diff can be committed separately from any refactoring, plumbing, cleanup, etc that are not strictly necessary to achieve the goal. Any of the latter should go only into master and ride the normal stabilization schedule. Exceptions include CI/metrics changes, CLI improvements and documentation updates on a case by case basis.

@KirillLykov KirillLykov force-pushed the klykov/reapply-3423 branch 2 times, most recently from 69e7397 to 657ba60 Compare January 10, 2025 12:46
@t-nelson
Copy link

This PR only moves these structures and makes a couple of small changes in the way config is passed

the and here is the problem. i cannot confidently review such changes when made in the same commit and cannot approve changes that i cannot confidently review

i say ideally these be separate PRs due to our being forced to use squash+merge and running into changes made like this during a crises is pure hell to sift through for relevancy while debugging

@KirillLykov KirillLykov force-pushed the klykov/reapply-3423 branch 3 times, most recently from 3d9a0dc to 1f2bd11 Compare January 13, 2025 12:41
@KirillLykov
Copy link
Author

KirillLykov commented Jan 13, 2025

@t-nelson I've updated this PR such that it doesn't move structures to new modules (I think this adds the main complexity). This is done in a follow up PR: https://github.com/anza-xyz/agave/compare/master...KirillLykov:klykov/reapply-3423-2?expand=1

I honestly expected that during procedure of adding back reverted PRs we will assume that they have been reviewed and only API changes will be addressed. I'm not against of another reviews generally, just afraid that splitting them might lead to a longer trip to 2.1

let wire_transactions = wire_transactions.iter().map(|t| t.to_vec()).collect();
let conn = connection_cache.get_connection(tpu_address);
conn.send_data_batch_async(wire_transactions)
pub trait TransactionClient {
Copy link
Author

Choose a reason for hiding this comment

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

This client wraps all the logic related to the leader selection together with sending transactions. This effectively splits the networking code from the rest opening the route for the replacement of the network code in the follow up PRs.

"Starting send-transaction-service::receive_txn_thread with config {:?}",
config
);
info!("Starting send-transaction-service::receive_txn_thread with config.",);

Choose a reason for hiding this comment

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

what is the value of this log if we're no longer emitting the config?

Copy link
Author

Choose a reason for hiding this comment

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

just for debugging purposes, I like to know when this thread has started, so make it debug

Choose a reason for hiding this comment

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

this instance is still info!() tho

Copy link
Author

Choose a reason for hiding this comment

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

I changed similar message in another thread, now fix in this one.

This is the same as PR#3423 but with minimized API changes in STS.
In order to be able to use new client code in the `SendTransactionService`, I need to wrap network-related code with the new structure ConnectionCacheClient.
To to that I also had to move some auxiliary code into separate files.
transactions: &mut HashMap<Signature, TransactionInfo>,
leader_info_provider: &Arc<Mutex<CurrentLeaderInfo<T>>>,
connection_cache: &Arc<ConnectionCache>,
config: &Config,

Choose a reason for hiding this comment

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

should similarly avoid destructure here

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
v2.1 Backport to v2.1 branch
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants