-
Notifications
You must be signed in to change notification settings - Fork 470
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
Support Collectible Dynamic Assemblies #473
Comments
There has been at least one StackOverflow question which seems related to just this.
I haven't thought it through all the way, one thing that perhaps would have to be pointed out in the documentation is that dynamic assemblies could be collected only once their associated |
Yep, that was my intention. There are heaps of limitations to the feature and it would really only fit the scenario of plugins or something similar where you dump everything and start again without restarting the process, most applications obviously don't work this way. I only logged the issue after reading the .NET Core 3.0 release notes and doing a little bit of investigation into how it works, so thought I'd capture my notes. |
I admire your efforts and persistence over the years, as well as the rigorous way to discuss issues! Thank |
Hello, I´m currently extending plugins system which based on AspNetBoilareplate framework and this enhancement will help me to create more dynamic dev worklow. When plugins DLLs changes in CORE project I desperately need to unload / reload this plugins assemblies., It works thanks custom AssemblyLoadContext, but after that I have this error:
So I vote +1 for this. Tahanks! |
Hi @jonorossi, I stumbled into that issues through Something like: Assembly.GetExecutingAssembly().IsCollectible ? AssemblyBuilderAccess.RunAndCollect : AssemblyBuilderAccess.Run; Using collectible assemblies is not common so I feel like it would have limited repercussions. |
If we use |
If this is generally true, then it would seem to be the death sentence for this enhancement, since (I assume) assemblies that use DynamicProxy will typically not be collectible. I wonder if the feature would still be worth having (as an opt-in) for the few remaining cases (like @mhascak's, see above). |
In some scenarios, it's needed. for example, the component using DynamicProxy is just a plugin in my application, and i want to load and hot unload it at runtime, sometimes for dynamic update. I used DynamicProxy to create http client proxy, before, all my components is collectible plugins, but now they are not. |
Do we have any update on this? Or an EST? I am facing the same scenario where I need to generate dynamic proxies on both collectible ALC and default ALC side. But I kept getting "A non-collectible assembly may not reference a collectible assembly" |
As we are pretty busy working on Unity with CoreCLR, we got hit by this issue, and we have a proposed fix here: #679 |
We are also facing this issue, where we have a dynamic proxy intercepting a target with a type defined in a collectible assembly. I validated that the proposed PR solves the issue, albeit I had to explicitly change the default to RunAndCollect (the load context was not collectible, but the referenced assembly by the generated proxy was). |
I've been reviewing @simonferquel's PR #679 again. (Thanks again for the initiative of putting it together!) While I'm not opposed to it in principle, there's one thing that bothers me about it: the introduction of It then occurred to me that we might already have all necessary abstractions in place to enable -var generator = new ProxyGenerator();
+var generator = new ProxyGenerator(new CollectibleProxyBuilder()); This follows an already established pattern that's used on .NET 4 to make the generated assemblies persistable to disk: var generator = new ProxyGenerator(new PersistentProxyBuilder()); I think this would be slightly cleaner than introducing a global static option switch. @simonferquel's PR includes additional logic such that DynamicProxy automatically chooses between Any thoughts or opinions on this? |
I verified that the proposed alternate PR works as expected when integrated in our code base, and that's OK. From a design point of view, I find it slightly more elegant and more in line with the current library design than the initial proposal. |
@ydie22, thanks for the positive feedback. As to your question, nothing prevents us from going forward and merging this extension. And it took so long because (apparently) this wasn't important enough for anyone to take the initiative... until quite recently. Remember this open-source project is essentially unpaid work, and we don't have many people maintaining it anymore... both of us have lately been busy with life outside Castle so things have progressed even slower. :-/ I'm happy to go ahead with this though if it's good enough for everyone. |
With these changes I was able to migrate my project from netFramework to netCore, thank you. 👍 Really looking forward to these changes.😎 |
.NET Core 3.0 introduces support for unloading assemblies after loading them into a custom
AssemblyLoadContext
via the newUnload
method and constructor withisCollectible
parameter. The customAssemblyLoadContext
is set up to only contain the assemblies you want with everything else being in the default context. Obviously this is a .NET Core 3.0 feature, and .NET Framework will never support it; .NET Standard also does not defineSystem.Runtime.Loader
classes. Unfortunately it looks like dynamic assemblies were missed (https://github.com/dotnet/corefx/issues/38426) and support for them won't make the cut for .NET Core 3.0..NET Framework 4.0 introduced
AssemblyBuilderAccess.RunAndCollect
which allows dynamic assemblies to be garbage collected when no reference is held.RunAndCollect
has a whole heap of restrictions on what can be emitted into the assembly (e.g. no COM interop), but I think we could fairly trivially add opt-in for this perModuleScope
to make it disposable.I don't know how useful this feature would actually be since we don't get any requests for it, but logging this as an enhancement to raise the topic since it is possible. It sounds like it
RunAndCollect
could be helpful for #472.The text was updated successfully, but these errors were encountered: