數據庫配置文件: conn.php <?php define("MONITORED_IP", "172.16.0.191"); //被監控的服務器IP地址 也就是本機地址 define("DB_SERVER", "172.16.7.2"); //存放數據的服務器IP地址 define("DB_USER", "root"); define("DB_PWD","111111"); define("DB_NMAE","performance"); class MyConnect{ public function connect($db_server,$db_user,$db_pwd,$db_name){ $conn = mysql_connect($db_server,$db_user,$db_pwd); if (!$conn){ die('連接數據庫失敗: ' . mysql_error()); } $flag = mysql_select_db($db_name,$conn); if(!$flag){ echo "<p align='center'>數據庫連接出錯!</p>";exit(); }else{ mysql_query("SET NAMES UTF8"); } } } ?> 獲取服務器性能CPU、內存、硬盤等使用率 get_used_status.php <?php include("conn.php"); $obj_MyConnect = new MyConnect(); $obj_MyConnect -> connect(DB_SERVER,DB_USER,DB_PWD,DB_NMAE); function get_used_status(){ $fp = popen('top -b -n 2 | grep -E "^(Cpu|Mem|Tasks)"',"r");//獲取某一時刻系統cpu和內存使用情況 $rs = ""; while(!feof($fp)){ $rs .= fread($fp,1024); } pclose($fp); $sys_info = explode("\n",$rs); $tast_info = explode(",",$sys_info[3]);//進程 數組 $cpu_info = explode(",",$sys_info[4]); //CPU占有量 數組 $mem_info = explode(",",$sys_info[5]); //內存占有量 數組 //正在運行的進程數 $tast_running = trim(trim($tast_info[1],'running')); //CPU占有量 $cpu_usage = trim(trim($cpu_info[0],'Cpu(s): '),'%us'); //百分比 //內存占有量 $mem_total = trim(trim($mem_info[0],'Mem: '),'k total'); $mem_used = trim($mem_info[1],'k used'); $mem_usage = round(100*intval($mem_used)/intval($mem_total),2); //百分比 $fp = popen('df -lh | grep -E "^(/)"',"r"); $rs = fread($fp,1024); pclose($fp); $rs = preg_replace("/\s{2,}/",' ',$rs); //把多個空格換成 “_” $hd = explode(" ",$rs); $hd_avail = trim($hd[3],'G'); //磁盤可用空間大小 單位G $hd_usage = trim($hd[4],'%'); //掛載點 百分比 //print_r($hd); //檢測時間 $fp = popen("date +"%Y-%m-%d %H:%M"","r"); $rs = fread($fp,1024); pclose($fp); $detection_time = trim($rs); return array('cpu_usage'=>$cpu_usage,'mem_usage'=>$mem_usage,'hd_avail'=>$hd_avail,'hd_usage'=>$hd_usage,'tast_running'=>$tast_running,'detection_time'=>$detection_time); } //echo date("Y-m-d H:i:s",time())."<br>"; $status=get_used_status(); $sql = "insert into performance(ip,cpu_usage,mem_usage,hd_avail,hd_usage,tast_running,detection_time) "; $sql .= " value('".MONITORED_IP."','".$status['cpu_usage']."','".$status['mem_usage']."','".$status['hd_avail']."','".$status['hd_usage']."','".$status['tast_running']."','".$status['detection_time']."')"; $query = mysql_query($sql) or die("SQL 語句執行失敗!"); unset($status); //echo date("Y-m-d H:i:s",time())."<br>"; ?> include("conn.php"); $obj_MyConnect = new MyConnect(); $obj_MyConnect -> connect(DB_SERVER,DB_USER,DB_PWD,DB_NMAE); function get_used_status(){ $fp = popen('top -b -n 2 | grep -E "^(Cpu|Mem|Tasks)"',"r");//獲取某一時刻系統cpu和內存使用情況 $rs = ""; while(!feof($fp)){ $rs .= fread($fp,1024); } pclose($fp); $sys_info = explode("\n",$rs); $tast_info = explode(",",$sys_info[3]);//進程 數組 $cpu_info = explode(",",$sys_info[4]); //CPU占有量 數組 $mem_info = explode(",",$sys_info[5]); //內存占有量 數組 //正在運行的進程數 $tast_running = trim(trim($tast_info[1],'running')); //CPU占有量 $cpu_usage = trim(trim($cpu_info[0],'Cpu(s): '),'%us'); //百分比 //內存占有量 $mem_total = trim(trim($mem_info[0],'Mem: '),'k total'); $mem_used = trim($mem_info[1],'k used'); $mem_usage = round(100*intval($mem_used)/intval($mem_total),2); //百分比 $fp = popen('df -lh | grep -E "^(/)"',"r"); $rs = fread($fp,1024); pclose($fp); $rs = preg_replace("/\s{2,}/",' ',$rs); //把多個空格換成 “_” $hd = explode(" ",$rs); $hd_avail = trim($hd[3],'G'); //磁盤可用空間大小 單位G $hd_usage = trim($hd[4],'%'); //掛載點 百分比 //print_r($hd); //檢測時間 $fp = popen("date +"%Y-%m-%d %H:%M"","r"); $rs = fread($fp,1024); pclose($fp); $detection_time = trim($rs); return array('cpu_usage'=>$cpu_usage,'mem_usage'=>$mem_usage,'hd_avail'=>$hd_avail,'hd_usage'=>$hd_usage,'tast_running'=>$tast_running,'detection_time'=>$detection_time); } //echo date("Y-m-d H:i:s",time())."<br>"; $status=get_used_status(); $sql = "insert into performance(ip,cpu_usage,mem_usage,hd_avail,hd_usage,tast_running,detection_time) "; $sql .= " value('".MONITORED_IP."','".$status['cpu_usage']."','".$status['mem_usage']."','".$status['hd_avail']."','".$status['hd_usage']."','".$status['tast_running']."','".$status['detection_time']."')"; $query = mysql_query($sql) or die("SQL 語句執行失敗!"); unset($status); //echo date("Y-m-d H:i:s",time())."<br>"; ?>