Windows使用java過程獲取作業系統磁碟以及記憶體資訊
記憶體:先建立一個表, 然後呼叫作業系統命令獲取記憶體容量等資訊
create table os_meminfo(info VARCHAR2(4000))
/
create or replace and compile java source named syscmd as
import java.io.*;
import java.lang.*;
import oracle.sql.*;
import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class syscmd extends Object{
public static void runcmd(int bufSize, String command, String result[]){
//String result;
String returnResult;
int i = 0;
try {
Process p;
p = Runtime.getRuntime().exec(command);
//BufferedInputStream bis=new BufferedInputStream(p.getInputStream(),bufSize);
//byte buffer[]=new byte[bufSize];
BufferedInputStream in = new BufferedInputStream(p.getInputStream());
BufferedReader inBr = new BufferedReader(new InputStreamReader(in));
String lineStr;
while ((lineStr = inBr.readLine()) != null) {
//System.out.println(lineStr);
if(lineStr.indexOf("記憶體") > 0) {
System.out.println(lineStr);
#sql{insert into os_meminfo(info) values(:lineStr)};
}
}
//while(bis.read(buffer,0,bufSize)!=-1);
//System.out.write(buffer,0,len);
p.waitFor();
// for(int i= 0; i<=buffer.length; i++){
//System.out.println(new String(buffer));
//returnResult = new String(buffer);
//#sql{insert into scott.meminfo3 values(:returnResult)};
//returnResult = returnResult.substring(2000, 4000);
// #sql{insert into scott.meminfo3 values(:returnResult)};
//}
inBr.close();
in.close();
}catch (Exception e){
e.printStackTrace();
}
}
}
/
CREATE OR REPLACE procedure syscmd( bufsize in number, cmd in varchar2, result out varchar2) as
language java
name 'syscmd.runcmd(int, java.lang.String, java.lang.String[])';
CREATE OR REPLACE PROCEDURE sysinfo_test AS
res VARCHAR2(256);
BEGIN
syscmd(50000000, 'C:\Windows\System32\systeminfo.exe', res);
dbms_output.put_line(res);
END;
/
呼叫:
begin
delete from os_meminfo;
sysinfo_test;
commit;
end;
磁碟:
create table os_disk_usage(
disk_name varchar2(200),
free number,
total number
)
/
create or replace and compile java source named mydiskusage as
import java.io.File;
import java.text.DecimalFormat;
public class MyDiskUsage {
public static void main(String[] args) {
File[] roots = File.listRoots();// 獲取磁碟分割槽列表
for (File file : roots) {
System.out.println(file.getPath() + "資訊如下:");
long free = file.getFreeSpace();
long total = file.getTotalSpace();
long use = total - free;
System.out.println("空閒未使用 = " + change(free) + "G");// 空閒空間
System.out.println("已經使用 = " + change(use) + "G");// 可用空間
System.out.println("總容量 = " + change(total) + "G");// 總空間
System.out.println("使用百分比 = " + bfb(use, total));
System.out.println();
}
}
public static void getDiskUage() throws java.sql.SQLException{
//System.out.println("HELLLLL00000000000");
File[] roots = File.listRoots();// 獲取磁碟分割槽列表
System.out.println(roots.length);
for (File file : roots) {
String diskName = file.getPath();
long free = file.getFreeSpace();
long total = file.getTotalSpace();
long use = total - free;
System.out.println(diskName + "total:" + total);
#sql{insert into h2.os_disk_usage( disk_name,free,total) values(:diskName,:free, :total)};
}
}
public static long change(long num) {
// return num;
return num / 1024 / 1024 / 1024;
}
public static String bfb(Object num1, Object num2) {
double val1 = Double.valueOf(num1.toString());
double val2 = Double.valueOf(num2.toString());
if (val2 == 0) {
return "0.0%";
} else {
DecimalFormat df = new DecimalFormat("#0.00");
return df.format(val1 / val2 * 100) + "%";
}
}
}
/
create or replace procedure mydiskusage
as
language java name 'MyDiskUsage.getDiskUage()';
BEGIN
DELETE FROM os_disk_usage;
mydiskusage;
COMMIT;
END;
以上過程均以sys使用者執行。非sys使用者, 需要授權(dbms_java.grant_permission)
create table os_meminfo(info VARCHAR2(4000))
/
create or replace and compile java source named syscmd as
import java.io.*;
import java.lang.*;
import oracle.sql.*;
import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class syscmd extends Object{
public static void runcmd(int bufSize, String command, String result[]){
//String result;
String returnResult;
int i = 0;
try {
Process p;
p = Runtime.getRuntime().exec(command);
//BufferedInputStream bis=new BufferedInputStream(p.getInputStream(),bufSize);
//byte buffer[]=new byte[bufSize];
BufferedInputStream in = new BufferedInputStream(p.getInputStream());
BufferedReader inBr = new BufferedReader(new InputStreamReader(in));
String lineStr;
while ((lineStr = inBr.readLine()) != null) {
//System.out.println(lineStr);
if(lineStr.indexOf("記憶體") > 0) {
System.out.println(lineStr);
#sql{insert into os_meminfo(info) values(:lineStr)};
}
}
//while(bis.read(buffer,0,bufSize)!=-1);
//System.out.write(buffer,0,len);
p.waitFor();
// for(int i= 0; i<=buffer.length; i++){
//System.out.println(new String(buffer));
//returnResult = new String(buffer);
//#sql{insert into scott.meminfo3 values(:returnResult)};
//returnResult = returnResult.substring(2000, 4000);
// #sql{insert into scott.meminfo3 values(:returnResult)};
//}
inBr.close();
in.close();
}catch (Exception e){
e.printStackTrace();
}
}
}
/
CREATE OR REPLACE procedure syscmd( bufsize in number, cmd in varchar2, result out varchar2) as
language java
name 'syscmd.runcmd(int, java.lang.String, java.lang.String[])';
CREATE OR REPLACE PROCEDURE sysinfo_test AS
res VARCHAR2(256);
BEGIN
syscmd(50000000, 'C:\Windows\System32\systeminfo.exe', res);
dbms_output.put_line(res);
END;
/
呼叫:
begin
delete from os_meminfo;
sysinfo_test;
commit;
end;
磁碟:
create table os_disk_usage(
disk_name varchar2(200),
free number,
total number
)
/
create or replace and compile java source named mydiskusage as
import java.io.File;
import java.text.DecimalFormat;
public class MyDiskUsage {
public static void main(String[] args) {
File[] roots = File.listRoots();// 獲取磁碟分割槽列表
for (File file : roots) {
System.out.println(file.getPath() + "資訊如下:");
long free = file.getFreeSpace();
long total = file.getTotalSpace();
long use = total - free;
System.out.println("空閒未使用 = " + change(free) + "G");// 空閒空間
System.out.println("已經使用 = " + change(use) + "G");// 可用空間
System.out.println("總容量 = " + change(total) + "G");// 總空間
System.out.println("使用百分比 = " + bfb(use, total));
System.out.println();
}
}
public static void getDiskUage() throws java.sql.SQLException{
//System.out.println("HELLLLL00000000000");
File[] roots = File.listRoots();// 獲取磁碟分割槽列表
System.out.println(roots.length);
for (File file : roots) {
String diskName = file.getPath();
long free = file.getFreeSpace();
long total = file.getTotalSpace();
long use = total - free;
System.out.println(diskName + "total:" + total);
#sql{insert into h2.os_disk_usage( disk_name,free,total) values(:diskName,:free, :total)};
}
}
public static long change(long num) {
// return num;
return num / 1024 / 1024 / 1024;
}
public static String bfb(Object num1, Object num2) {
double val1 = Double.valueOf(num1.toString());
double val2 = Double.valueOf(num2.toString());
if (val2 == 0) {
return "0.0%";
} else {
DecimalFormat df = new DecimalFormat("#0.00");
return df.format(val1 / val2 * 100) + "%";
}
}
}
/
create or replace procedure mydiskusage
as
language java name 'MyDiskUsage.getDiskUage()';
BEGIN
DELETE FROM os_disk_usage;
mydiskusage;
COMMIT;
END;
以上過程均以sys使用者執行。非sys使用者, 需要授權(dbms_java.grant_permission)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8520577/viewspace-2144553/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 獲取windows 作業系統下的硬體或作業系統資訊等Windows作業系統
- Android中獲取系統記憶體資訊以及程式資訊-----ActivityManager的使用(一)Android記憶體
- windows作業系統支援的最大記憶體Windows作業系統記憶體
- Sigar獲取作業系統資訊作業系統
- vmi:獲取 windows 系統硬體資訊Windows
- Winrm 獲取遠端windows伺服器 cpu、磁碟、記憶體Windows伺服器記憶體
- 作業系統-記憶體管理作業系統記憶體
- 作業系統——記憶體管理作業系統記憶體
- 直播軟體搭建,java程式碼獲取記憶體資訊Java記憶體
- psutil獲取作業系統負載資訊作業系統負載
- linux查詢作業系統資訊(CPU、記憶體、硬碟)Linux作業系統記憶體硬碟
- 作業系統記憶體管理概述作業系統記憶體
- 作業系統記憶體管理-原理作業系統記憶體
- 【作業系統】記憶體管理概述作業系統記憶體
- [zt] 如何使作業系統使用超過4G的記憶體作業系統記憶體
- shell採集系統cpu 記憶體 磁碟 網路資訊記憶體
- 作業系統的虛擬記憶體作業系統記憶體
- 作業系統-記憶體、檔案管理作業系統記憶體
- C#獲取CPU佔用率、記憶體佔用、磁碟佔用、程式資訊C#記憶體
- Windows 作業系統引導過程 BIOS & EFIWindows作業系統iOS
- MySQL記憶體管理,記憶體分配器和作業系統MySql記憶體作業系統
- 作業系統——記憶體管理學習筆記作業系統記憶體筆記
- windows以及linux獲取系統時間WindowsLinux
- 獲取作業系統型別作業系統型別
- Linux作業系統記憶體淺析Linux作業系統記憶體
- HP-UX作業系統的記憶體UX作業系統記憶體
- 計算機作業系統——虛擬記憶體與實體記憶體計算機作業系統記憶體
- windows程式/執行緒建立過程 --- windows作業系統學習Windows執行緒作業系統
- 使用32位 Windows 作業系統時避免記憶體問題的五個建議Windows作業系統記憶體
- 在Delphi程式設計中獲取作業系統資訊 (轉)程式設計作業系統
- 檢視CentOS伺服器的cpu、記憶體、作業系統版本資訊CentOS伺服器記憶體作業系統
- 關於安裝VMware以及Linux作業系統過程Linux作業系統
- 作業系統的記憶體管理你知道嗎作業系統記憶體
- 淺談作業系統對記憶體的管理作業系統記憶體
- Windows作業系統磁碟清理的新概念(轉)Windows作業系統
- python使用wmi模組獲取windows下的系統資訊 監控系統PythonWindows
- 通過 HelloWorld 瞭解 Java 程式執行過程以及執行時記憶體Java記憶體
- Windows系統安全獲取重要資訊的方法(一)Windows