Solved

Retriving event logs faster vb.net

Posted on 2009-07-02
7
2,211 Views
Last Modified: 2013-11-08
Hello,

Today i use below function:

 Dim entry As EventLogEntry
            Dim EL As New EventLog("Application", server, service)
  For Each entry In EL.Entries
 If entry.Source = service Then

That works and all but the log file is sometimes very big which makes this function take very long time, even when i have specified a source in EL's properties it seams to download everything, thats why the if statement.  Is there anyway i can filter the source, and maybe the time before i actually downloading all the logs? if not, any other way to optimize this code to make it faster?

Kind regards,
Peter Hillerberg
0
Comment
Question by:carnegieuk
  • 3
  • 2
  • 2
7 Comments
 
LVL 9

Assisted Solution

by:Rahul Goel
Rahul Goel earned 70 total points
ID: 24770505
If you're both on Vista or Windows Server 2008, you're in luck. You should look at the new System.Diagnostics.Eventing.Reader.EventLogQuery and System.Diagnostics.Eventing.Reader.EventLogReader. These are new in .net 3.5.

Basically, you can build a query in XML and ship it over
0
 
LVL 9

Assisted Solution

by:Rahul Goel
Rahul Goel earned 70 total points
ID: 24770509
and you can use BackgroundWorker Thread with async results.
0
 
LVL 53

Accepted Solution

by:
Dhaest earned 430 total points
ID: 24770511
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.

 

Author Comment

by:carnegieuk
ID: 24770523
Thanks very much for such a quick reply, however we are still on 2003... :(

any other possible solution?
0
 

Author Comment

by:carnegieuk
ID: 24770738
Thanks Dhaest,

I get an error when i run this:
Operation is not supported on this platform.

just wrote a shot test, but for some reason it's not working.

its netframework 3.5 (vb 2008 express)
the server i adress is 2003 sp2 i run it on a server 2003 sp2.

any ideas?

thanks!
Private Sub getmessages()

        

        Dim queryString As String = "*[System/Level=2]"  ' XPATH Query
 

        Dim session As EventLogSession = New EventLogSession(serverrc)
 

        ' Query the Application log on the remote computer.

        Dim query As EventLogQuery = New EventLogQuery( _

            "Application", PathType.LogName, queryString)

        query.Session = session
 

        Try
 

            Dim logReader As New EventLogReader(query)
 

            ' Display query results.

            DisplayEventAndLogInformation(logReader)
 

        Catch e As EventLogException
 

            MsgBox("Could not query the remote computer! " & e.Message)

            Return

        End Try
 
 

    End Sub
 
 
 

    Private Sub DisplayEventAndLogInformation(ByVal logReader As EventLogReader)
 

        Dim eventInstance As EventRecord = logReader.ReadEvent()

        While Not eventInstance Is Nothing

            ' Display event info

            MsgBox("-----------------------------------------------------")

            MsgBox("Event ID: {0}", eventInstance.Id)

            MsgBox("Publisher: {0}", eventInstance.ProviderName)
 
 

            Try

                MsgBox("Description: {0}", eventInstance.FormatDescription())
 

            Catch e As EventLogException
 

                ' The event description contains parameters, and no parameters were 

                ' passed to the FormatDescription method, so an exception is thrown.
 

            End Try
 

            eventInstance = logReader.ReadEvent()
 

            ' Cast the EventRecord object as an EventLogRecord object to 

            ' access the EventLogRecord class properties.

            Dim logRecord As EventLogRecord = CType(eventInstance, EventLogRecord)

            MsgBox("Container Event Log: {0}", logRecord.ContainerLog)

        End While
 

    End Sub

        Dim queryString As String = "*[System/Level=2]"  ' XPATH Query
 

        Dim session As EventLogSession = New EventLogSession(serverrc)
 

        ' Query the Application log on the remote computer.

        Dim query As EventLogQuery = New EventLogQuery( _

            "Application", PathType.LogName, queryString)

        query.Session = session
 

        Try
 

            Dim logReader As New EventLogReader(query)
 

            ' Display query results.

            DisplayEventAndLogInformation(logReader)
 

        Catch e As EventLogException
 

            MsgBox("Could not query the remote computer! " & e.Message)

            Return

        End Try
 
 

    End Sub
 
 
 
 
 

    Private Sub DisplayEventAndLogInformation(ByVal logReader As EventLogReader)
 

        Dim eventInstance As EventRecord = logReader.ReadEvent()

        While Not eventInstance Is Nothing

            ' Display event info

            MsgBox("-----------------------------------------------------")

            MsgBox("Event ID: {0}", eventInstance.Id)

            MsgBox("Publisher: {0}", eventInstance.ProviderName)
 
 

            Try

                MsgBox("Description: {0}", eventInstance.FormatDescription())
 

            Catch e As EventLogException
 

                ' The event description contains parameters, and no parameters were 

                ' passed to the FormatDescription method, so an exception is thrown.
 

            End Try
 

            eventInstance = logReader.ReadEvent()
 

            ' Cast the EventRecord object as an EventLogRecord object to 

            ' access the EventLogRecord class properties.

            Dim logRecord As EventLogRecord = CType(eventInstance, EventLogRecord)

            MsgBox("Container Event Log: {0}", logRecord.ContainerLog)

        End While
 

    End Sub

Open in new window

0
 
LVL 53

Assisted Solution

by:Dhaest
Dhaest earned 430 total points
ID: 24772370
Where exactly do you get the error ?
0
 

Author Comment

by:carnegieuk
ID: 24821011
Sorry dont remember where i got the problem exactly and i dont have the time to test this now. i have kinda solved it reading other logfile with same information. Thank you so much for your help.

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

Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
It was really hard time for me to get the understanding of Delegates in C#. I went through many websites and articles but I found them very clumsy. After going through those sites, I noted down the points in a easy way so here I am sharing that unde…
Along with being a a promotional video for my three-day Annielytics Dashboard Seminor, this Micro Tutorial is an intro to Google Analytics API data.
Learn how to create flexible layouts using relative units in CSS.  New relative units added in CSS3 include vw(viewports width), vh(viewports height), vmin(minimum of viewports height and width), and vmax (maximum of viewports height and width).

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

19 Experts available now in Live!

Get 1:1 Help Now