Solved

Exception occurred while reading xml configuration file from windows service

Posted on 2009-04-06
8
1,119 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
 
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
DevOps Toolchain Recommendations

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

 
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

3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

Question has a verified solution.

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

This document covers how to connect to SQL Server and browse its contents.  It is meant for those new to Visual Studio and/or working with Microsoft SQL Server.  It is not a guide to building SQL Server database connections in your code.  This is mo…
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…

910 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

16 Experts available now in Live!

Get 1:1 Help Now