-
-
Notifications
You must be signed in to change notification settings - Fork 160
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
Allow changing options in live client #97
base: master
Are you sure you want to change the base?
Conversation
* New Client::change_options method that changes the options and reopens a new transport using the new options. * Change of return types of Client::options() and Client::dsn() because of internal changes.
It's currently quite intentional that changes to the options are not possible. I would be curious how this is useful because it introduces some things that make the integration code much more complex (they can no longer rely on options being immutable). |
Well, a lot of services are OK to be restarted, because they contain little state and start up fast. However, this is not always the case. Few examples:
In these cases, it is desirable the service or daemon can reload and update the configuration at runtime. While sentry configuration is probably not part of the thing you want to usually update at runtime for these, the situation when some subset of all config doesn't update when requested is surprising. And my own motivation is, I'm trying to create a library that helps with these kinds of reloadable daemons (https://crates.io/crates/spirit). I'd like to add a support for sentry too ‒ that the application would just include a configuration fragment in its config definition and the library would take care of the rest. However, I can't do that if there's no way to either update the configuration or maybe somehow tear down and re-initialize it at runtime. |
@vorner i'm just not sure why you need to be able to reconfigure the client instead of just making a new client and binding it. This enables the hot reload situation with configuration changes and we're using that ourselves. |
That's what I intended to do at first. But then I started to read the documentation and code and came to a conclusion it wouldn't work and started to look for other options. Maybe the conclusion is wrong, but this is what I seem to be reading:
Or do I read the code wrong? How is it supposed to work or be used? Thank you |
@vorner That is correct. Each thread until the end of its lifetime will hold on to the old hub which is intentional. If you have long running threads that you want to reconfigure the hub on you would have to keep track of all hubs created. I'm not sure yet what an improvement here would look like but i worry about making the options writable. That causes all kinds of concurrency issues. |
Hmm. Many applications have long-running threads (especially the ones I mentioned above), but keeping track of them could be challenging. For example, the default tokio runtime keeps a threadpool and spawns and shuts down threads as needed, but most of them will live long. The I agree that my solution is a bit hacky, but it felt like the smallest change I could do. Brainstorming some ideas what might be helpful from
Would anything like that make sense? |
Ping? I don't insist on this particular approach, but I'd appreciate a suggestion what would be a viable way forward. |
@vorner we will revisit this soon. I don't have a good solution to this yet :( There is no stack of hubs, just a stack within the hub. I agree that enumerating hubs is not a great solution. My best suggestion right now is more indirection which I'm not super happy with. |
Hello Was there a conclusion? |
Hi! While I do think its a valid usecase, it is kind of niche, and we don‘t know yet how it really fits into the Unified API design. However, I noticed that the way the current Client works is a bit suboptimal right now. I imagine to make the Client a newtype around |
Thank you for looking at that. I'd say that reconfiguring doesn't really need to be efficient as it happens only as a result of user interaction ‒ therefore only once every blue moon. |
My concern is rather the overhead of locking and arc-ing all the time even though you never re-configure. I think the best way forward here would be to actually measure and benchmal all this. I would love to have at least some benchmarks/numbers for:
I would especially love to prove with numbers that client impl feature is useless, and be able to remove it, since it is super painful to maintain. Especially now that the core is getting more modular, compilation times and dependencies become less of a concern. |
I'll admit I don't remember much of the details and haven't looked under the hood recently, so I guess a bit about a lot of what you talk about. Nevertheless, if the concern is about the Arc and RwLock, I'll do a shameless plug here. I have this arc-swap library that could replace it but be possibly much faster. It's less powerfull (you probably could not outright mutate the client, only replace it as a whole). Furthermore, with the Cache it's possible to make even faster, but with some other drawbacks (like old never-to-be-used-again clients may stay around for longer time). |
Hello
I'd like to have a way to change all the configuration of my application at runtime. That would also mean being able changing configuration of sentry and I didn't find a way to do it with current API. I noticed there's a way to bind a new client into the main Hub. However, if I read the code correctly, derived thread-local hubs clone
Arc
to the client on creation. That would mean that if I ever change the client in the main hub, only new threads would get the new client and previous threads would keep the old one.This addition would allow me to replace the „insides“ of a client ‒ change its options and transport and it would be reflected in all the hubs.
Does that make sense? Or is there a better way to reach the goal, or some other API change that would make it possible?
Unfortunately, because of the changes inside Client, I had to change the return values of two reader methods, which would make this a semver-incompatible change ☹.