Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

Create custom eventlog

Posted on 2008-06-14
4
Medium Priority
?
3,662 Views
Last Modified: 2010-04-21
Hi all,

I am creating an custom eventlog using the code below.
The eventlog and source will be created fine but something strange happens when I write to the log:

This customlog and the Application log keep track of the same entries! So whenever I write an entry to my custom log it will also show up in the application log. And, whenever any application logs to the application log, it will also show up in my custom log.

I have never seen this before. I used this piece of code many times but always on a Windows XP development machine.
Now I am developing on a Windows Server 2003 machine...

Does anybody know how to solve this issue so that the logs are not interconnected anymore?

Thanks!

D'Mzz!
RoverM

EventLog _eLog;
string sourceName = "MyService v2.1";
string logName = "MyService";
 
if (!EventLog.SourceExists(sourceName))
{
   EventSourceCreationData data = new EventSourceCreationData(sourceName, logName);
   EventLog.CreateEventSource(data);
}
 
EventLog[] logs = EventLog.GetEventLogs();
if (logs != null)
{
   foreach (EventLog log in logs)
   {
      if (log.Log == logName)
      {
         if (log.OverflowAction != OverflowAction.OverwriteAsNeeded)
            log.ModifyOverflowPolicy(OverflowAction.OverwriteAsNeeded, 1);
         this._eLog = log;
         this._eLog.Source = sourceName;
         break;
      }
   }
}

Open in new window

0
Comment
Question by:roverm
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
4 Comments
 
LVL 12

Accepted Solution

by:
jandromeda earned 2000 total points
ID: 21810068
Try this code.
string logName = "TestLog";
			string logSource = "TestSource";
			EventLog myLog = null;
			
			if (!EventLog.Exists(logName))
			{
				EventLog.CreateEventSource(logSource, logName);
			}
			
			EventLog[] logs = EventLog.GetEventLogs();
			
			foreach (EventLog log in logs)
			{
				if (log.Log == logName)
				{
					myLog = log;
					myLog.Source = logSource;
					myLog.WriteEntry("TestMessage2");
					break;
				}
			}

Open in new window

0
 
LVL 12

Author Comment

by:roverm
ID: 21815783
@jandromeda: Thanks but this gives me the exact same situation...
0
 
LVL 12

Author Comment

by:roverm
ID: 21837766
Ok: I have tried my own code on another computer (same os) and on this one it works just fine.

Closing it...
0
 
LVL 12

Author Closing Comment

by:roverm
ID: 31467193
Thanks.
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

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

We all know that functional code is the leg that any good program stands on when it comes right down to it, however, if your program lacks a good user interface your product may not have the appeal needed to keep your customers happy. This issue can…
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
Sometimes it takes a new vantage point, apart from our everyday security practices, to truly see our Active Directory (AD) vulnerabilities. We get used to implementing the same techniques and checking the same areas for a breach. This pattern can re…
Want to learn how to record your desktop screen without having to use an outside camera. Click on this video and learn how to use the cool google extension called "Screencastify"! Step 1: Open a new google tab Step 2: Go to the left hand upper corn…

610 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