-
Notifications
You must be signed in to change notification settings - Fork 4.8k
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
machine.config for .NET Core #32307
Comments
I spaced on the change away from The idea here was that you could still set for whichever runtime instance that you were using. You could trump the settings completely, which isn't possible if we load the implicit one. I don't recall if you can override the config sections from the higher-level config, but I think the answer is no. If so, this can potentially be problematic when you take user config files into account. |
@JeremyKuhne - I'm not sure I follow your response. Do you agree with the proposal to remove trying to probe for a If we shouldn't remove it, what do you propose we do instead? I don't think we should probe the |
Yes, the need to trump it so you can inject in front of the user.config is important. I'm ok with making the probe app-specific, but I think we still need it. |
Do we know about anybody who is using this override for real app? |
I don't believe anyone is using this if we can absorb this breaking change in 5.0.0 that seems best to do now (rather than do it in 6.0.0 which we expect to move to LTS). If it breaks anyone they can revert to an earlier package and let us know they need it and we can bring it back. |
@safern I don't think this meets the bar at this point in 5.0.0. Moving out. |
We have a system with lot of services/APIs with .NET 461 .NET472 and have a huge dependency on the machine level config files. I do not find any consistent solution, especially every new version update, changes the path to the runtime/sdk. Therefore I resort to defining the global config location for our middleware (hundreds of) services/APIs. This is our approach. If this is more or less the standard or the right way, then skipping .NET dependency completely away from Machine config should be taken and highlighted clearly in the documentation. Thanks, Habib |
[Triage] Seems it's non essential for 6.0. |
Can anyone answer Where is the machine.config for linux ? I wanted to set <system.web>
<processModel maxWorkerThreads="100" maxIoThreads="100" minWorkerThreads="50"/>
<httpRuntime minFreeThreads="704" minLocalRequestFreeThreads="608"/>
</system.web> putting machine.config in the root directory doesn't seem to have worked. We only have web.config in root directory. We run it as dotnet app.dll --urls=http://0.0.0.0:5000 |
I assume that you are using ASP.NET Core. machine.config and web.config is not used by ASP.NET Core. ASP.NET Core uses different configuration system, documented at https://learn.microsoft.com/en-us/aspnet/core/fundamentals/configuration |
In the .NET Framework,
System.Configuration
allowed amachine.config
file that would apply globally to every .NET process on the machine.https://docs.microsoft.com/en-us/dotnet/framework/configure-apps/#machine-configuration-files
This made sense, because you could configure the framework using this file, and it would apply for all processes.
In .NET Core this concept makes much less sense.
System.Configuration
. Instead, we useruntimeconfig.json
.Today in .NET Core, when you use the
System.Configuration.ConfigurationManager
package, it will still try to load amachine.config
file, however the location it probes for this file is relative to the current application (usingAppDomain.CurrentDomain.BaseDirectory
):runtime/src/libraries/System.Configuration.ConfigurationManager/src/System/Configuration/ClientConfigurationHost.cs
Lines 43 to 56 in 571f972
(NOTE: For .NET Core 2.0, the code still used the old .NET Framework implementation of calling
RuntimeEnvironment.GetRuntimeDirectory()
to get the directory. This was changed in 2.1 to useBaseDirectory
with dotnet/corefx#20488.)Typically that file never exists. When if it doesn't
ConfigurationManager
will load a default/hard-coded machine.config:runtime/src/libraries/System.Configuration.ConfigurationManager/src/System/Configuration/ImplicitMachineConfigHost.cs
Lines 75 to 95 in 4107a4c
The problem with the current behavior comes when
AppDomain.CurrentDomain.BaseDirectory
doesn't return a path. For example, when using a custom native host - see #25027 -BaseDirectory
returnsnull
.In this situation,
ConfigurationManager
tries to load aConfig/machine.config
stream. And since this path isn't rooted, it tries to issue aWebRequest
for this stream:runtime/src/libraries/System.Configuration.ConfigurationManager/src/System/Configuration/ClientConfigurationHost.cs
Lines 281 to 299 in 4107a4c
WebClient
is smart enough to realize this is a request for a file, tries to load the file - relative to the current working directory, which is probably not good from a security perspective. When the file doesn't exist it throws a few 1st chance exceptions, which are caught and thennull
is returned.Proposal
We should just cut support for reading a
machine.config
file completely from ConfigurationManager on .NET Core and always return the default/hard-coded machine.config contents. No need to probe for files that don't exist. No need to issue a WebRequest and catch exceptions either.All settings can be overridden by the App.config. And since we are only probing the app's directory (or the current working directory if using a native host) it doesn't make sense to split the configuration across multiple files in the app's directory.
/cc @ericstj @JeremyKuhne @maryamariyan @safern
The text was updated successfully, but these errors were encountered: