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 equivalent to HttpRequest's @RequestScope #1017

Open
hrothwell opened this issue Apr 23, 2024 · 4 comments
Open

Kafka equivalent to HttpRequest's @RequestScope #1017

hrothwell opened this issue Apr 23, 2024 · 4 comments

Comments

@hrothwell
Copy link

Feature description

We have the ability to make a @RequestScope bean in Micronaut which ties a bean to the current HttpRequest the server is executing on, would it be possible to do something similar for a Kafka message/batch of messages/etc?

@hrothwell hrothwell changed the title Kafka poll equivalent to HttpRequests @RequestScope Kafka equivalent to HttpRequest's @RequestScope Apr 23, 2024
@graemerocher
Copy link
Contributor

probably, would require implementing a custom scope and binding the scope to a thread. Could probably use AbstractConcurrentCustomScope

@hrothwell
Copy link
Author

I'll do some digging on it at some point this week if I get time, thanks for the lead as to where to look

@hrothwell
Copy link
Author

hrothwell commented Jun 7, 2024

I did spend some time today digging through this with mostly more questions than answers (wip branch for reference) , but to document some notes / ideas / findings / etc about it:

  • My initial use case was to have a simple POJO bean for holding a value that was either constantly recalculated or passed through dozens of function calls. Usually this is something like the current date time at the time the whole chain started, where if you recalculate it you can sometimes cross into a new day, which can throw off any calculations that might care about what day it is.
  • What I was envisioning was something similar to the RequestScope beans (we have used these in apis for this same purpose), but as I was going through I found myself focusing more on trying to merge the ideas of ThreadLocal and Refreshable
    • Each consumer instance might need its own instance of this bean. This bean would also need to refresh just before processRecords, in the use case described above this would have to pause execution until said refreshing was completed and before calling to process
    • because of the need for this type of refreshing, I started taking a look more at Refreshable and thinking if there was possibly some other solution other than a new custom scope. The one idea I had and something that potentially has the use outside of just this example: Allowing for the refreshing of speciic beans before a particular method is called. Something like a @Refreshes(beans = {BeanTypeToRefresh.class}, qualifiers = {/* maybe qualifiers could also be applied in the case of multiple beans of said types */}) method annotation.
      • to maybe then simplify the initial use case, you could just annotate your consumer's entrypoint with @Refreshes.
      • One other benefit to this and one of the issues I was considering that brought me here: perhaps most of the app logic is shared by both a consumer and an HTTP endpoint, in which case you would want both to trigger this bean to update. However, maybe that leads back to the needing to be bound to whatever thread is executing... Hadn't gotten that far in thinking about it until I started typing this out 🤔

@hrothwell
Copy link
Author

random weekend brain thoughts that I am putting down to not forget:

could it be ThreadLocal but then also have a "refresh" function on the bean that is called every poll loop?

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

No branches or pull requests

2 participants