-
Notifications
You must be signed in to change notification settings - Fork 3.9k
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
Bump Khepri to 0.17.0 #12753
base: main
Are you sure you want to change the base?
Bump Khepri to 0.17.0 #12753
Conversation
6d289fe
to
cc6185d
Compare
5cb0a79
to
42f571a
Compare
deps/rabbit/src/rabbit_db_queue.erl
Outdated
case khepri_tx_adv:delete(Path) of | ||
%% Khepri 0.16 and below returned `khepri:node_props()' for | ||
%% adv queries and commands targeting one node: | ||
{ok, #{data := _}} -> | ||
%% we want to execute some things, as decided by rabbit_exchange, | ||
%% after the transaction. | ||
rabbit_db_binding:delete_for_destination_in_khepri(QueueName, OnlyDurable); | ||
%% Khepri 0.17+ returns `khepri_adv:node_props_map()` | ||
%% instead. | ||
{ok, #{Path := #{data := _}}} -> | ||
rabbit_db_binding:delete_for_destination_in_khepri(QueueName, OnlyDurable); |
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.
Oh, that’s a good point! This probably needs a fix in Khepri. I see two solutions:
- The typespec is updated to document the old return value (which it can return)
- The function converts the old return value to the new one (I didn’t check if it was possible though)
What do you think?
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.
Do we need a change in Khepri? rabbitmq/khepri#303 only touched the "client" code (i.e. not khepri_machine
) so older versions should continue to see khepri:node_props()
while newer versions consistently see khepri_adv:node_props_map()
, even if the leader were an older versioned node.
The typespec change is unfortunate and the dialyzer had a few complaints that I worked around with -dialyzer({nowarn_function, [..]}).
attributes. I think this is ok for compatibility code like this. We should be able to delete these branches and remove the dialyzer ignores for 4.2.x once we don't need compatibility with Khepri 0.16. (Assuming Khepri 0.17 would ship with 4.1.x.)
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.
newer versions consistently see khepri_adv:node_props_map(), even if the leader were an older versioned node.
Right, we have reply_from => LocalMember
for commands, so the return value is created by the local version of Khepri. Then, why do we need to have the case
for both return values?
With the discussions around long-term support for RabbitMQ, compatibility code can stay for a long time as we will have to support upgrades that skip versions. That said, it might not be the case with RabbitMQ 4.0.x. This is more of a general comment.
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.
Oh actually that's a really good point, I suppose the old return value isn't possible and we shouldn't need this compatibility code
2d1225d
to
17e7652
Compare
Khepri v0.17 needs a change in Ra 2.15.0 that exposes more data in the `ra_aux` API.
`locally_known_members/1` and `locally_known_node/1` were replaced with `members/2` and `nodes/2` with `favor` set to `low_latency` - this matches the interface for queries in Khepri.
All callers of `khepri_adv` and `khepri_tx_adv` need updates to handle the now consistent return type of `khepri:node_props_map()` in Khepri 0.17. We don't need any compatibility code to handle "either the old return type or the new return type" because the translation is done entirely in the "client side" code in Khepri - meaning that the return value from the Ra server is the same but it is translated differently by the functions in `khepri_adv` and `khepri_tx_adv`.
17e7652
to
d4c49f2
Compare
This is not ready to be merged yet, Khepri 0.17.0 hasn't yet been released. (And we want to make more changes before then anyways.)
This PR handles the breaking changes in Khepri 0.17.0.