How to use different .settings files for different environments in .NET?

前端 未结 6 793
温柔的废话
温柔的废话 2021-02-02 01:11

.NET allows you to use .settings files to manage application settings. I would like to store Production, Development and Test settings separately in a way that I can do somethi

相关标签:
6条回答
  • 2021-02-02 01:43

    Just some extra info on .NET environment based config files without using your above implementation specifically:

    The Enterprise Library has this feature since V3.0: Summary

    Visual Studio 2010 will have this feature also. Its called Config Transformation

    0 讨论(0)
  • 2021-02-02 01:47

    Just an idea but it may work...

    • You'll need N+2 settings files (N different builds; 2 masters) with containing the same keys.

    • Clear out the "Custom Tool" property for all of them but one of the masters (so only one the master generates).

    • Modify the pre-build script for each release to copy the appropriate settings file contents into the build-master file.

    • Modify the post-build script to copy the secondary master file contents back in to the original master file.

    Note: If you can work with your source control provider in the pre- and post-build scripts, you don't need a secondary master -- you can just check out in the pre-build and undo check out in the post-build. However, this may cause issues in a continuous integration environment since a locked file would require the build to fail.

    I've also never done this; though there are times I wished there was a more up-front way of doing something like this in VS.

    0 讨论(0)
  • 2021-02-02 01:54

    One thought is that switching between a series of static values sounds like a rather fraught way of doing things. I would suggest looking up the Singleton pattern. This pattern gives you a single class instance that is shared between all references to the class, but when it's first loaded you can do your normal initialisation bits to check your environment and set the values accordingly.

    Equally, rather than using switches to act on different classes, wouldn't you be looking at designing one Interface, and having each class implement that interface?

    0 讨论(0)
  • 2021-02-02 01:59

    I am using this approach for .config files, I am sure that it will help you too. Just look on Scott Hanselman's blog post and this question. Ideology is simple like hell, but works pretty good. All you will need is:

    1. create several files for different configurations
    2. name them by convention, e.g. my.dev.settings, my.live.settings
    3. create post build event (see links)
    4. enjoy =)

    Instantiation code for you class with settings will always look in default settings (which will be replaced after each build with the needed one), so this approach require minimal effort.

    0 讨论(0)
  • 2021-02-02 02:01

    I currently do something similar to the solution mentioned by pdavis. But to simplifying multiple config files I use a T4 templates to create the environment specific config files. That way there is one web.tt file that handles the generation of the default web.config file. Each environment has its own template file (qa.tt, production.tt, etc) that inherits from web.tt and contains any environment specific overrides. Any changes to web config - new app settings, configuration settings, etc. are automatically propagated to all region specific config files by regenerating the templates, and you don't have to worry about keeping files in sync using a diff tool.

    0 讨论(0)
  • 2021-02-02 02:10

    There is a bit of overhead involved in making a check to determine what environment you are running in. If you are talking a web environment then this could mean a significant performance hit. I would recommend creating three separate config files and setting up a continuous integration and deployment system that handles the naming and roll out of the proper settings file based on environment. In your case you would have three files, Production.config, Development.config, and Test.config. The integration server would then create a copy of this file for web.config or app.config based on the environment.

    As far as any additional maintenance involved with maintaining three separate files whenever a configuration change is made, we keep the files auto-formatted and use something like WinMerge to easily see differences and keep them in proper sync. These type of files typically do not require many changes and when they do they are usually minor additions.

    0 讨论(0)
提交回复
热议问题