<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DZone Snippets: uptime code</title>
    <link>http://snippets.dzone.com/posts</link>
    <pubDate>Thu, 21 Aug 2008 13:49:31 GMT</pubDate>
    <description>DZone Snippets: uptime code</description>
    <item>
      <title>Get uptime of remote computer using WMI</title>
      <link>http://snippets.dzone.com/posts/show/5472</link>
      <description>// description of your code here&lt;br /&gt;Get uptime of remote computer using WMI, I'm not sure the convert time function is correct, it gives different results than psinfo.exe&lt;br /&gt;&lt;code&gt;&lt;br /&gt;&lt;br /&gt;Private Function GetUptime() As String&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;        Dim WMIScope As Management.ManagementScope&lt;br /&gt;        Dim WMIConnectionOptions As New Management.ConnectionOptions&lt;br /&gt;        Dim strRootDomain As String&lt;br /&gt;        Dim objRootLDAP As DirectoryEntry&lt;br /&gt;        Dim query As ManagementObjectSearcher&lt;br /&gt;        Dim queryCollection As ManagementObjectCollection&lt;br /&gt;        Dim oq As New System.Management.ObjectQuery&lt;br /&gt;        Dim mo As New ManagementObject&lt;br /&gt;        Dim perftimestamp As String = ""&lt;br /&gt;        Dim perttimefreq As String = ""&lt;br /&gt;        Dim counter As String = ""&lt;br /&gt;        Dim iUptimeInSec As Long = 0&lt;br /&gt;&lt;br /&gt;        With WMIConnectionOptions&lt;br /&gt;            .Impersonation = System.Management.ImpersonationLevel.Impersonate&lt;br /&gt;            .Authentication = System.Management.AuthenticationLevel.Packet&lt;br /&gt;&lt;br /&gt;        End With&lt;br /&gt;&lt;br /&gt;        WMIScope = New Management.ManagementScope("\\" &amp; _&lt;br /&gt;        Strcomputer &amp; "\root\cimv2", WMIConnectionOptions)&lt;br /&gt;&lt;br /&gt;        objRootLDAP = New DirectoryEntry("LDAP://RootDSE")&lt;br /&gt;        strRootDomain = objRootLDAP.Properties.Item("rootDomainNamingContext").Value.ToString&lt;br /&gt;&lt;br /&gt;        oq = New System.Management.ObjectQuery("select * from Win32_PerfRawData_PerfOS_System")&lt;br /&gt;        query = New ManagementObjectSearcher(WMIScope, oq)&lt;br /&gt;        queryCollection = query.Get()&lt;br /&gt;&lt;br /&gt;        For Each oReturn As ManagementObject In queryCollection&lt;br /&gt;            perftimestamp = oReturn("Timestamp_Object").ToString()&lt;br /&gt;            perttimefreq = oReturn("Frequency_Object").ToString()&lt;br /&gt;            counter = oReturn("SystemUpTime").ToString()&lt;br /&gt;        Next&lt;br /&gt;&lt;br /&gt;        ' Calculation in seconds:&lt;br /&gt;        iUptimeInSec = Convert.ToInt64((Double.Parse(perftimestamp) - Double.Parse(counter)) / Double.Parse(perttimefreq))&lt;br /&gt;&lt;br /&gt;        ' convert the seconds&lt;br /&gt;        Return ConvertTime(iUptimeInSec)&lt;br /&gt;&lt;br /&gt;    End Function&lt;br /&gt;&lt;br /&gt;    Private Function ConvertTime(ByVal seconds As Long) As String&lt;br /&gt;&lt;br /&gt;        Dim ConvSec As Long&lt;br /&gt;        Dim ConvMin As Long&lt;br /&gt;        Dim ConvHour As Long&lt;br /&gt;        Dim ConvDays As Long&lt;br /&gt;&lt;br /&gt;        Math.DivRem(seconds, 60, ConvSec)&lt;br /&gt;&lt;br /&gt;        Math.DivRem(seconds, 3600, ConvMin)&lt;br /&gt;        ConvMin = ConvMin / 60&lt;br /&gt;&lt;br /&gt;        Math.DivRem(seconds, (3600 * 24), ConvHour)&lt;br /&gt;        ConvHour = ConvHour / 3600&lt;br /&gt;&lt;br /&gt;        ConvDays = (seconds / (3600 * 24))&lt;br /&gt;&lt;br /&gt;        Return (ConvDays.ToString() + " days " + ConvHour.ToString() + " hours " + ConvMin.ToString() + " minutes " + ConvSec.ToString() + " seconds ")&lt;br /&gt;&lt;br /&gt;    End Function&lt;br /&gt;&lt;br /&gt;'or you could try this method which still doesn't match psinfo or systeminfo but it is closer&lt;br /&gt;&lt;br /&gt;Private Function GetUptime2() As String&lt;br /&gt;&lt;br /&gt;        Dim WMIScope As Management.ManagementScope&lt;br /&gt;        Dim WMIConnectionOptions As New Management.ConnectionOptions&lt;br /&gt;        Dim strRootDomain As String&lt;br /&gt;        Dim objRootLDAP As DirectoryEntry&lt;br /&gt;        Dim query As ManagementObjectSearcher&lt;br /&gt;        Dim queryCollection As ManagementObjectCollection&lt;br /&gt;        Dim oq As New System.Management.ObjectQuery&lt;br /&gt;        Dim mo As New ManagementObject&lt;br /&gt;        Dim perftimestamp As String = ""&lt;br /&gt;        Dim perttimefreq As String = ""&lt;br /&gt;        Dim counter As String = ""&lt;br /&gt;        Dim iUptimeInSec As Long = 0&lt;br /&gt;        Dim LastBootUpTime As DateTime&lt;br /&gt;        Dim dateNow As DateTime = Date.Now&lt;br /&gt;&lt;br /&gt;        With WMIConnectionOptions&lt;br /&gt;            .Impersonation = System.Management.ImpersonationLevel.Impersonate&lt;br /&gt;            .Authentication = System.Management.AuthenticationLevel.Packet&lt;br /&gt;&lt;br /&gt;        End With&lt;br /&gt;&lt;br /&gt;        WMIScope = New Management.ManagementScope("\\" &amp; _&lt;br /&gt;        Strcomputer &amp; "\root\cimv2", WMIConnectionOptions)&lt;br /&gt;&lt;br /&gt;        objRootLDAP = New DirectoryEntry("LDAP://RootDSE")&lt;br /&gt;        strRootDomain = objRootLDAP.Properties.Item("rootDomainNamingContext").Value.ToString&lt;br /&gt;&lt;br /&gt;        oq = New System.Management.ObjectQuery("Select * from Win32_OperatingSystem")&lt;br /&gt;&lt;br /&gt;        query = New ManagementObjectSearcher(WMIScope, oq)&lt;br /&gt;        queryCollection = query.Get()&lt;br /&gt;&lt;br /&gt;        For Each oReturn As ManagementObject In queryCollection&lt;br /&gt;&lt;br /&gt;            LastBootUpTime = System.Management.ManagementDateTimeConverter.ToDateTime(oReturn("LastBootUpTime").ToString)&lt;br /&gt;            &lt;br /&gt;        Next&lt;br /&gt;&lt;br /&gt;        Dim ts As TimeSpan = dateNow.Subtract(LastBootUpTime)&lt;br /&gt;        Console.WriteLine(ts.Days.ToString + " days " + ts.Hours.ToString + " hours " + ts.Minutes.ToString + " minutes " + ts.Seconds.ToString + " seconds ")&lt;br /&gt;&lt;br /&gt;    End Function&lt;br /&gt;&lt;br /&gt;&lt;/code&gt;</description>
      <pubDate>Wed, 07 May 2008 15:20:08 GMT</pubDate>
      <guid>http://snippets.dzone.com/posts/show/5472</guid>
      <author>mellerbeck (Michael Ellerbeck)</author>
    </item>
  </channel>
</rss>
