java调用windows的wmi获取设备性能数据

java调用windows的wmi获取监控数据(100%纯java调用windows的wmi获取监控数据)

转:http://my.oschina.net/noahxiao/blog/73163

纯java主要体现在可以跨平台调用com。所用的是j-Interop,它是100%纯java实现的com的调用

1、环境准备

a、windows要开启Remote Registry与Windows Management Instrumentation服务

b、修改安全策略

我系统是英文的,如果是中文系统,翻译为中文,相对应的查找并修改。

Administrative Tools>Local Security Policy>Local Policy>Security Policy>Network access: Sharing and security model for local accounts

修改为Classic(经典)

c、禁用放火墙

d、window2008系统注册表越狱(高版本的win)

需要修改regedit中HKEY_CLASSES_ROOT\CLSID\{76A64158-CB41-11D1-8B02-00600806D9B6}的权限,windows2008不再给Administrators完全控制权。

下载SetACL.exe,下载地址:http://files.helgeklein.com/downloads/SetACL/current/SetACL%20(executable%20version).zip

set_wmi_reg_acl.cmd

1
    SetACL.exe -on "HKEY_CLASSES_ROOT\CLSID\{76A64158-CB41-11D1-8B02-00600806D9B6}" -ot reg -actn setowner -ownr "n:Administrators"
2
    SetACL.exe -on "HKEY_CLASSES_ROOT\CLSID\{76A64158-CB41-11D1-8B02-00600806D9B6}" -ot reg -actn ace -ace "n:Administrators;p:full"

以超级管理员身份执行这个cms,就会把owner与完全控制权限授予Administrators组

2、程序代码
java类
001
    package org.noah.wmitest;
002
    
003
    import org.jinterop.dcom.common.JIException;
004
    import org.jinterop.dcom.common.JISystem;
005
    import org.jinterop.dcom.core.*;
006
    import org.jinterop.dcom.impls.JIObjectFactory;
007
    import org.jinterop.dcom.impls.automation.IJIDispatch;
008
    import org.jinterop.dcom.impls.automation.IJIEnumVariant;
009
    import org.slf4j.Logger;
010
    import org.slf4j.LoggerFactory;
011
    
012
    import java.net.UnknownHostException;
013
    import java.util.logging.Level;
014
    
015
    /**
016
     * Created with IntelliJ IDEA.
017
     * User: noah
018
     * Date: 8/16/12
019
     * Time: 8:00 AM
020
     * To change this template use File | Settings | File Templates.
021
     */
022
    public class WmiService {
023
    
024
        private JIComServer m_ComStub = null;
025
        private IJIComObject m_ComObject = null;
026
        private IJIDispatch m_Dispatch = null;
027
        private String m_Address = null;
028
        private JISession m_Session = null;
029
        private IJIDispatch m_WbemServices = null;
030
    
031
        private static final String WMI_CLSID = "76A6415B-CB41-11d1-8B02-00600806D9B6";
032
        private static final String WMI_PROGID = "WbemScripting.SWbemLocator";
033
    
034
        private Logger logger = LoggerFactory.getLogger(this.getClass());
035
    
036
    
037
        public WmiService(String address) {
038
            JISystem.setAutoRegisteration(true);
039
            JISystem.getLogger().setLevel(Level.WARNING);
040
            m_Address = address;
041
        }
042
    
043
        public void query(String strQuery) {
044
    
045
            System.out.println("query:" + strQuery);
046
    
047
            JIVariant results[] = new JIVariant[0];
048
            try {
049
                results = m_WbemServices.callMethodA("ExecQuery", new Object[]{new JIString(strQuery), JIVariant.OPTIONAL_PARAM(), JIVariant.OPTIONAL_PARAM(), JIVariant.OPTIONAL_PARAM()});
050
                IJIDispatch wOSd = (IJIDispatch) JIObjectFactory.narrowObject((results[0]).getObjectAsComObject());
051
    
052
                int count = wOSd.get("Count").getObjectAsInt();
053
    
054
                IJIComObject enumComObject = wOSd.get("_NewEnum").getObjectAsComObject();
055
                IJIEnumVariant enumVariant = (IJIEnumVariant) JIObjectFactory.narrowObject(enumComObject.queryInterface(IJIEnumVariant.IID));
056
    
057
                IJIDispatch wbemObject_dispatch = null;
058
    
059
                for (int c = 0; c < count; c++) {
060
    
061
                    Object[] values = enumVariant.next(1);
062
                    JIArray array = (JIArray) values[0];
063
                    Object[] arrayObj = (Object[]) array.getArrayInstance();
064
                    for (int j = 0; j < arrayObj.length; j++) {
065
                        wbemObject_dispatch = (IJIDispatch) JIObjectFactory.narrowObject(((JIVariant) arrayObj[j]).getObjectAsComObject());
066
                    }
067
    
068
                    String str = (wbemObject_dispatch.callMethodA("GetObjectText_", new Object[]{1}))[0].getObjectAsString2();
069
                    System.out.println("(" + c + "):");
070
                    System.out.println(str);
071
                    System.out.println();
072
                }
073
    
074
    
075
            } catch (JIException e) {
076
                e.printStackTrace();
077
            }
078
        }
079
    
080
        public void connect(final String domain, final String username, final String password) {
081
            try {
082
    
083
                m_Session = JISession.createSession(domain, username, password);
084
                m_Session.useSessionSecurity(true);
085
                m_Session.setGlobalSocketTimeout(5000);
086
    
087
                m_ComStub = new JIComServer(JIProgId.valueOf(WMI_PROGID), m_Address, m_Session);
088
    
089
                IJIComObject unknown = m_ComStub.createInstance();
090
                m_ComObject = unknown.queryInterface(WMI_CLSID);
091
    
092
                m_Dispatch = (IJIDispatch) JIObjectFactory.narrowObject(m_ComObject.queryInterface(IJIDispatch.IID));
093
                JIVariant results[] = m_Dispatch.callMethodA(
094
                        "ConnectServer",
095
                        new Object[]{
096
                                new JIString(m_Address),
097
                                JIVariant.OPTIONAL_PARAM(),
098
                                JIVariant.OPTIONAL_PARAM(),
099
                                JIVariant.OPTIONAL_PARAM(),
100
                                JIVariant.OPTIONAL_PARAM(),
101
                                JIVariant.OPTIONAL_PARAM(),
102
                                0,
103
                                JIVariant.OPTIONAL_PARAM()
104
                        }
105
                );
106
    
107
                m_WbemServices = (IJIDispatch) JIObjectFactory.narrowObject((results[0]).getObjectAsComObject());
108
    
109
            } catch (JIException e) {
110
                e.printStackTrace();
111
                if (m_Session != null) {
112
                    try {
113
                        JISession.destroySession(m_Session);
114
                    } catch (JIException e1) {
115
                        logger.error(e.getMessage(), e);
116
                    }
117
                }
118
            } catch (UnknownHostException e) {
119
                if (m_Session != null) {
120
                    try {
121
                        JISession.destroySession(m_Session);
122
                    } catch (JIException e1) {
123
                        logger.error(e.getMessage(), e);
124
                    }
125
                }
126
            }
127
        }
128
    
129
        public void disconnect() {
130
            try {
131
                JISession.destroySession(m_Session);
132
            } catch (JIException e) {
133
                logger.error(e.getMessage(), e);
134
            }
135
        }
136
    
137
    
138
        public static void main(String[] args) {
139
    
140
            WmiService wmiService = new WmiService("172.16.158.129");
141
    
142
            //域(一般为空字符),用户名,密码
143
            wmiService.connect("", "username", "password");
144
    
145
            //系统信息
146
            wmiService.query("SELECT * FROM Win32_ComputerSystem");
147
    
148
            //CPU信息
149
            wmiService.query("SELECT * FROM Win32_PerfFormattedData_PerfOS_Processor WHERE Name != '_Total'");
150
    
151
            //内存信息
152
            wmiService.query("SELECT * FROM Win32_PerfFormattedData_PerfOS_Memory");
153
    
154
            //磁盘信息
155
            wmiService.query("SELECT * FROM Win32_PerfRawData_PerfDisk_PhysicalDisk Where Name != '_Total'");
156
    
157
            wmiService.disconnect();
158
        }
159
    }

mavne配置(pom.xml)
01
    <?xml version="1.0" encoding="UTF-8"?>
02
    <project xmlns="http://maven.apache.org/POM/4.0.0"
03
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
04
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
05
        <modelVersion>4.0.0</modelVersion>
06
    
07
        <groupId>org.noahx</groupId>
08
        <artifactId>wmi-test</artifactId>
09
        <version>1.0</version>
10
    
11
    
12
        <dependencies>
13
    
14
            <dependency>
15
                <groupId>org.kohsuke.jinterop</groupId>
16
                <artifactId>j-interop</artifactId>
17
                <version>2.0.8-kohsuke-1</version>
18
            </dependency>
19
    
20
            <dependency>
21
                <groupId>org.slf4j</groupId>
22
                <artifactId>slf4j-log4j12</artifactId>
23
                <version>1.6.4</version>
24
            </dependency>
25
    
26
        </dependencies>
27
         
28
    </project>

运行结果
001
    query:SELECT * FROM Win32_ComputerSystem
002
    (0):
003
    
004
    instance of Win32_ComputerSystem
005
    {
006
        AdminPasswordStatus = 1;
007
        AutomaticResetBootOption = FALSE;
008
        AutomaticResetCapability = TRUE;
009
        BootOptionOnLimit = 3;
010
        BootOptionOnWatchDog = 3;
011
        BootROMSupported = TRUE;
012
        BootupState = "Normal boot";
013
        Caption = "NAK-E1A7C21EA3C";
014
        ChassisBootupState = 3;
015
        CreationClassName = "Win32_ComputerSystem";
016
        CurrentTimeZone = 480;
017
        Description = "AT/AT COMPATIBLE";
018
        Domain = "WORKGROUP";
019
        DomainRole = 0;
020
        EnableDaylightSavingsTime = TRUE;
021
        FrontPanelResetStatus = 3;
022
        InfraredSupported = FALSE;
023
        KeyboardPasswordStatus = 3;
024
        Manufacturer = "VMware, Inc.";
025
        Model = "VMware Virtual Platform";
026
        Name = "NAK-E1A7C21EA3C";
027
        NetworkServerModeEnabled = TRUE;
028
        NumberOfLogicalProcessors = 2;
029
        NumberOfProcessors = 1;
030
        OEMStringArray = {"[MS_VM_CERT/SHA1/27d66596a61c48dd3dc7216fd715126e33f59ae7]", "Welcome to the Virtual Machine"};
031
        PartOfDomain = FALSE;
032
        PauseAfterReset = "3932100000";
033
        PowerOnPasswordStatus = 0;
034
        PowerState = 0;
035
        PowerSupplyState = 3;
036
        PrimaryOwnerName = "nak";
037
        ResetCapability = 1;
038
        ResetCount = -1;
039
        ResetLimit = -1;
040
        Roles = {"LM_Workstation", "LM_Server", "NT", "Potential_Browser", "Master_Browser"};
041
        Status = "OK";
042
        SystemStartupDelay = 0;
043
        SystemStartupOptions = {"\"Microsoft Windows XP Professional\" /noexecute=optin /fastdetect"};
044
        SystemStartupSetting = 0;
045
        SystemType = "X86-based PC";
046
        ThermalState = 3;
047
        TotalPhysicalMemory = "1610063872";
048
        UserName = "NAK-E1A7C21EA3C\\a";
049
        WakeUpType = 6;
050
    };
051
    
052
    
053
    query:SELECT * FROM Win32_PerfFormattedData_PerfOS_Processor WHERE Name != '_Total'
054
    (0):
055
    
056
    instance of Win32_PerfFormattedData_PerfOS_Processor
057
    {
058
        C1TransitionsPersec = "77";
059
        C2TransitionsPersec = "0";
060
        C3TransitionsPersec = "0";
061
        DPCRate = 0;
062
        DPCsQueuedPersec = 4;
063
        InterruptsPersec = 71;
064
        Name = "0";
065
        PercentC1Time = "96";
066
        PercentC2Time = "0";
067
        PercentC3Time = "0";
068
        PercentDPCTime = "0";
069
        PercentIdleTime = "100";
070
        PercentInterruptTime = "0";
071
        PercentPrivilegedTime = "0";
072
        PercentProcessorTime = "0";
073
        PercentUserTime = "0";
074
    };
075
    
076
    
077
    (1):
078
    
079
    instance of Win32_PerfFormattedData_PerfOS_Processor
080
    {
081
        C1TransitionsPersec = "83";
082
        C2TransitionsPersec = "0";
083
        C3TransitionsPersec = "0";
084
        DPCRate = 0;
085
        DPCsQueuedPersec = 10;
086
        InterruptsPersec = 67;
087
        Name = "1";
088
        PercentC1Time = "96";
089
        PercentC2Time = "0";
090
        PercentC3Time = "0";
091
        PercentDPCTime = "0";
092
        PercentIdleTime = "100";
093
        PercentInterruptTime = "0";
094
        PercentPrivilegedTime = "0";
095
        PercentProcessorTime = "0";
096
        PercentUserTime = "0";
097
    };
098
    
099
    
100
    query:SELECT * FROM Win32_PerfFormattedData_PerfOS_Memory
101
    (0):
102
    
103
    instance of Win32_PerfFormattedData_PerfOS_Memory
104
    {
105
        AvailableBytes = "1142099968";
106
        AvailableKBytes = "1115332";
107
        AvailableMBytes = "1089";
108
        CacheBytes = "70725632";
109
        CacheBytesPeak = "72904704";
110
        CacheFaultsPersec = 634;
111
        CommitLimit = "3063078912";
112
        CommittedBytes = "326488064";
113
        DemandZeroFaultsPersec = 13965;
114
        FreeSystemPageTableEntries = 159743;
115
        PageFaultsPersec = 13965;
116
        PageReadsPersec = 0;
117
        PagesInputPersec = 0;
118
        PagesOutputPersec = 0;
119
        PagesPersec = 0;
120
        PageWritesPersec = 0;
121
        PercentCommittedBytesInUse = 10;
122
        PoolNonpagedAllocs = 38040;
123
        PoolNonpagedBytes = "7585792";
124
        PoolPagedAllocs = 57820;
125
        PoolPagedBytes = "29380608";
126
        PoolPagedResidentBytes = "28622848";
127
        SystemCacheResidentBytes = "40235008";
128
        SystemCodeResidentBytes = "1867776";
129
        SystemCodeTotalBytes = "1167360";
130
        SystemDriverResidentBytes = "0";
131
        SystemDriverTotalBytes = "4071424";
132
        TransitionFaultsPersec = 0;
133
        WriteCopiesPersec = 0;
134
    };
135
    
136
    
137
    query:SELECT * FROM Win32_PerfRawData_PerfDisk_PhysicalDisk Where Name != '_Total'
138
    (0):
139
    
140
    instance of Win32_PerfRawData_PerfDisk_PhysicalDisk
141
    {
142
        AvgDiskBytesPerRead = "138920448";
143
        AvgDiskBytesPerRead_Base = 8000;
144
        AvgDiskBytesPerTransfer = "208285696";
145
        AvgDiskBytesPerTransfer_Base = 13701;
146
        AvgDiskBytesPerWrite = "69365248";
147
        AvgDiskBytesPerWrite_Base = 5701;
148
        AvgDiskQueueLength = "581460650";
149
        AvgDiskReadQueueLength = "405581626";
150
        AvgDisksecPerRead = 2794786622;
151
        AvgDisksecPerRead_Base = 8000;
152
        AvgDisksecPerTransfer = 322083534;
153
        AvgDisksecPerTransfer_Base = 13701;
154
        AvgDisksecPerWrite = 1822264208;
155
        AvgDisksecPerWrite_Base = 5701;
156
        AvgDiskWriteQueueLength = "175879024";
157
        CurrentDiskQueueLength = 0;
158
        DiskBytesPersec = "208285696";
159
        DiskReadBytesPersec = "138920448";
160
        DiskReadsPersec = 8000;
161
        DiskTransfersPersec = 13701;
162
        DiskWriteBytesPersec = "69365248";
163
        DiskWritesPersec = 5701;
164
        Frequency_Object = "0";
165
        Frequency_PerfTime = "3034010000";
166
        Frequency_Sys100NS = "10000000";
167
        Name = "0 C:";
168
        PercentDiskReadTime = "405581626";
169
        PercentDiskReadTime_Base = "129895856572522792";
170
        PercentDiskTime = "581460650";
171
        PercentDiskTime_Base = "129895856572522792";
172
        PercentDiskWriteTime = "175879024";
173
        PercentDiskWriteTime_Base = "129895856572522792";
174
        PercentIdleTime = "18446744072967667781";
175
        PercentIdleTime_Base = "129895856572522792";
176
        SplitIOPerSec = 1074;
177
        Timestamp_Object = "0";
178
        Timestamp_PerfTime = "3635534093651";
179
        Timestamp_Sys100NS = "129895856572522792";
180
    };<span style="font-family:'sans serif, tahoma, verdana, helvetica';font-size:x-small;"><span style="line-height:18.18181800842285px;white-space:normal;"> </span></span>

3、有可能出现的问题
报错a
01
    org.jinterop.dcom.common.JIException: Message not found for errorCode: 0xC0000034
02
        at org.jinterop.winreg.smb.JIWinRegStub.winreg_OpenHKLM(JIWinRegStub.java:115)
03
        at org.jinterop.dcom.core.JIProgId.getIdFromWinReg(JIProgId.java:130)
04
        at org.jinterop.dcom.core.JIProgId.getCorrespondingCLSID(JIProgId.java:162)
05
        at org.jinterop.dcom.core.JIComServer.<init>(JIComServer.java:413)
06
        at org.noah.wmitest.WmiService.connect(WmiService.java:122)
07
        at org.noah.wmitest.WmiService.main(WmiService.java:177)
08
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
09
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
10
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
11
        at java.lang.reflect.Method.invoke(Method.java:597)
12
        at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
13
    Caused by: jcifs.smb.SmbException: The system cannot find the file specified.
14
        at jcifs.smb.SmbTransport.checkStatus(SmbTransport.java:522)
15
        at jcifs.smb.SmbTransport.send(SmbTransport.java:622)
16
        at jcifs.smb.SmbSession.send(SmbSession.java:239)
17
        at jcifs.smb.SmbTree.send(SmbTree.java:109)
18
        at jcifs.smb.SmbFile.send(SmbFile.java:718)
19
        at jcifs.smb.SmbFile.open0(SmbFile.java:923)
20
        at jcifs.smb.SmbFile.open(SmbFile.java:940)
21
        at jcifs.smb.SmbFileOutputStream.<init>(SmbFileOutputStream.java:142)
22
        at jcifs.smb.TransactNamedPipeOutputStream.<init>(TransactNamedPipeOutputStream.java:32)
23
        at jcifs.smb.SmbNamedPipe.getNamedPipeOutputStream(SmbNamedPipe.java:187)
24
        at rpc.ncacn_np.RpcTransport.attach(RpcTransport.java:92)
25
        at rpc.Stub.attach(Stub.java:105)
26
        at rpc.Stub.call(Stub.java:110)
27
        at org.jinterop.winreg.smb.JIWinRegStub.winreg_OpenHKLM(JIWinRegStub.java:113)
28
        ... 10 more

需要开启Remote Registry服务

报错b
01
    org.jinterop.dcom.common.JIException: Message not found for errorCode: 0xC0000001
02
        at org.jinterop.winreg.smb.JIWinRegStub.winreg_OpenHKLM(JIWinRegStub.java:115)
03
        at org.jinterop.dcom.core.JIProgId.getIdFromWinReg(JIProgId.java:130)
04
        at org.jinterop.dcom.core.JIProgId.getCorrespondingCLSID(JIProgId.java:162)
05
        at org.jinterop.dcom.core.JIComServer.<init>(JIComServer.java:413)
06
        at org.noah.wmitest.WmiService.connect(WmiService.java:87)
07
        at org.noah.wmitest.WmiService.main(WmiService.java:142)
08
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
09
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
10
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
11
        at java.lang.reflect.Method.invoke(Method.java:597)
12
        at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
13
    Caused by: jcifs.smb.SmbException: Connection timeout
14
    jcifs.util.transport.TransportException: Connection timeout
15
    
16
    或
17
    
18
    org.jinterop.dcom.common.JIException: Message not found for errorCode: 0x8001FFFF
19
        at org.jinterop.dcom.core.JIComServer.init(JIComServer.java:576)
20
        at org.jinterop.dcom.core.JIComServer.initialise(JIComServer.java:481)
21
        at org.jinterop.dcom.core.JIComServer.<init>(JIComServer.java:414)
22
        at org.noah.wmitest.WmiService.connect(WmiService.java:87)
23
        at org.noah.wmitest.WmiService.main(WmiService.java:142)
24
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
25
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
26
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
27
        at java.lang.reflect.Method.invoke(Method.java:597)
28
        at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
29
    Caused by: java.net.ConnectException: Connection timed out

需要禁用放火墙

4、总结
j-Interop纯java跨平台,我就是linux系统。
用j-Interop就可以很方便的调用windows系统com,虽然这里只演示了WMI。
如果关心WMI与监控的话,建议去opennms-wmi看一看,他们有更好api封装(底层也是j-Interop)。

上一篇:《java中异常和错误》


下一篇:198.打家劫舍