Solved

Exception occurred while reading xml configuration file from windows service

Posted on 2009-04-06
8
1,120 Views
Last Modified: 2013-12-17
We have below xml  configuration file.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
      <SQLServers>
            <add name="PERTRACQADB"/>
            <add name="DBNYC1"/>
            <add name="IRDB"/>
            <add name="IRTRACKERDB"/>
            <add name="LPCAPDB"/>
      </SQLServers>
      <PerTracServices>
            <add name="CMS-Email-Auto-Log"/>
            <add name="CMSImporter3SVC"/>
            <add name="DESVCDIR 2x5"/>
            <add name="SSUPDATES 2.0"/>
      </PerTracServices>
</configuration>
We are using C# code to read the configuration file as in code snippet.

We can successfully run the code to load the configuration file as an individual application but we are getting the following exception while we are running it as windows service and the service has been stopped abnormally.

EventType clr20r3, P1 pertracmonitor.service.exe, P2 1.0.0.0, P3 49d9e873, P4 system.configuration, P5 2.0.0.0, P6 461ef187, P7 1a6, P8 136, P9 ioibmurhynrxkw0zxkyrvfn0boyyufow, P10 NIL.

Service cannot be started. System.Configuration.ConfigurationErrorsException: Configuration system failed to initialize ---> System.Configuration.ConfigurationErrorsException: Unrecognized configuration section SQLServers. (C:\Program Files\PerTracMonitor\Setup\CustomActions\PerTracMonitor.Service.exe.config line 3)
   at System.Configuration.ConfigurationSchemaErrors.ThrowIfErrors(Boolean ignoreLocal)
   at System.Configuration.BaseConfigurationRecord.ThrowIfParseErrors(ConfigurationSchemaErrors schemaErrors)
   at System.Configuration.BaseConfigurationRecord.ThrowIfInitErrors()
   at System.Configuration.ClientConfigurationSystem.EnsureInit(String configKey)
   --- End of inner exception stack trace ---
   at System.Configuration.ClientConfigurationSystem.EnsureInit(String configKey)
   at System.Configuration.ClientConfigurationSystem.System.Configuration.Internal.IInternalConfigSystem.GetSection(String sectionName)
   at System.Configuration.ConfigurationManager.GetSection(String sectionName)
   at System.Configuration....

Can anyone please help me to resolve this.


private static void ConfigReader()
{
          
   try
   {
      string[] splitedPath = System.Reflection.Assembly.GetEntryAssembly().Location.Split(new char[] { '\\' });
      string parentDir = string.Join("\\", splitedPath, 0, splitedPath.Length - 1);
      string configFile = parentDir + "\\PerTracMonitor.xml";
      if (!File.Exists(configFile))
      {
         msgBody = "Configuration file not found.";
         sendEmail();
         return;
      }
              XmlDocument xml_doc = new XmlDocument();
               XmlNodeList childNodes = xml_doc.GetElementsByTagName("SQLServers");                
                foreach (XmlNode cNode in childNodes)                
                     SQLServers.Add(cNode.Attributes["name"].Value);
 
                childNodes = xml_doc.GetElementsByTagName("PerTracServices");
                foreach (XmlNode cNode in childNodes)
                     PerTracServices.Add(cNode.Attributes["name"].Value);
           }
            catch (System.Exception ex)
            {
               msgBody += "Exception occured while reading config file.\n";
                msgBody += ex.Message;
                sendEmail();
            }
}

Open in new window

0
Comment
Question by:deshaw
  • 4
  • 4
8 Comments
 
LVL 15

Expert Comment

by:angus_young_acdc
ID: 24077994
Why don't you just use ConfigurationManager?  Then you can use the ConnectionString property, or even just appsettings.  EG add this to your XML:
<add key="ConnectionString" value="YourConnectionString"/>

Then just call it:
string connection = ConfigurationManager.AppSettings["ConnectionString"];

Then you have your string easy.
0
 
LVL 1

Author Comment

by:deshaw
ID: 24084156

Thanks for your suggestion.

But I want to have two sections namely "SQLServers" and "PerTracServices" and I did not find the way to have sections in <appSettings>.  Could you please tell me how I can define the sections using <appSettings>.

I would be great full if you can find the reason for the exceptions while I am running the given code as a windows service.
0
 
LVL 15

Accepted Solution

by:
angus_young_acdc earned 500 total points
ID: 24084790
What is on line 3 of your config file?  It would make life a lot simpler for you to just use the ConfigurationManager from what I can see of your code.

Here would be an example of the App.Config file:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
  </configSections>
  <appSettings>
    <add key ="SQLServers" value="WhateverValue"/>
    <add key ="PerTracServices" value="WhateverValue"/>
  </appSettings>
</configuration>

You can then read any key you wish, and you can have as many as you want.  EG I changed your code to be like the following snippet, taking the value from the appSetting which you can use at anytime.

        private static void ConfigReader()
        {
 
            try
            {
                if (!File.Exists(configFile))
                {
                    msgBody = "Configuration file not found.";
                    sendEmail();
                    return;
                }
                else
                {
                    _sqlServers = ConfigurationManager.AppSettings["SQLServers"]; // declare _sqlServers as string
                    _perTracServices = ConfigurationManager.AppSettings["PerTracServices"]; // declare _perTracServices as string
                }
            }
            catch (System.Exception ex)
            {
                msgBody += "Exception occured while reading config file.\n";
                msgBody += ex.Message;
                sendEmail();
            }
        }

Open in new window

0
Master Your Team's Linux and Cloud Stack!

The average business loses $13.5M per year to ineffective training (per 1,000 employees). Keep ahead of the competition and combine in-person quality with online cost and flexibility by training with Linux Academy.

 
LVL 1

Author Comment

by:deshaw
ID: 24085327
Thank you.
I have tried the code. But it also gives the same problem. It works well if we are using it in an individual application but it is not getting values from the configuration file while running as windows service. It does not give any exceptions.
0
 
LVL 15

Expert Comment

by:angus_young_acdc
ID: 24086720
I have similar code and it works, very odd.   So for each service you have added the App.Config to the solution?  Services wouldn't really throw exceptions, they are more silent annoyances.  

Try declaring this at the top of your service:
private static readonly string _sqlServers =
                ConfigurationManager.AppSettings["SQLServers"]; etc.  
0
 
LVL 1

Author Comment

by:deshaw
ID: 24093501
Service is not throwing any exception but it is getting stopped immediately and I could see the reason for that in Application event log. It says the given exception in my main thread.
Thanks.
0
 
LVL 15

Expert Comment

by:angus_young_acdc
ID: 24146209
Yes, the exception causes your service to stop running.  Is your Config file formatted correctly?
0
 
LVL 1

Author Closing Comment

by:deshaw
ID: 31567009
thanks
0

Featured Post

DevOps Toolchain Recommendations

Read this Gartner Research Note and discover how your IT organization can automate and optimize DevOps processes using a toolchain architecture.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Welcome my friends to the second instalment and follow-up to our Minify and Concatenate Your Scripts and Stylesheets (http://www.experts-exchange.com/Programming/Languages/.NET/ASP.NET/A_4334-Minify-and-Concatenate-Your-Scripts-and-Stylesheets.html)…
More often than not, we developers are confronted with a need: a need to make some kind of magic happen via code. Whether it is for a client, for the boss, or for our own personal projects, the need must be satisfied. Most of the time, the Framework…
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

816 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now