-
Notifications
You must be signed in to change notification settings - Fork 309
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
base: master
Are you sure you want to change the base?
Conversation
If this PR represents a change to the public RPC API:
Thank you for keeping the RPC clients in sync with the server API @KirillLykov. |
78cadad
to
268f2a7
Compare
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 |
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> |
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.
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
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.
Done, added reexport of the public structures/const that have been moved.
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.
thanks! can you annotate with the rust attribute instead of a comment?
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. |
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. |
69e7397
to
657ba60
Compare
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 |
3d9a0dc
to
1f2bd11
Compare
1f2bd11
to
2f9e99a
Compare
@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 { |
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.
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.",); |
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.
what is the value of this log if we're no longer emitting the config?
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.
just for debugging purposes, I like to know when this thread has started, so make it debug
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.
this instance is still info!()
tho
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 changed similar message in another thread, now fix in this one.
2f9e99a
to
94445cd
Compare
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.
94445cd
to
f8deda1
Compare
f8deda1
to
ae303a5
Compare
transactions: &mut HashMap<Signature, TransactionInfo>, | ||
leader_info_provider: &Arc<Mutex<CurrentLeaderInfo<T>>>, | ||
connection_cache: &Arc<ConnectionCache>, | ||
config: &Config, |
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.
should similarly avoid destructure here
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 structureConnectionCacheClient
.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.