-
- 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","パフォーマンス");
-
- 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>";exit();
- }else{
- mysql_query("SET NAMES UTF8");
- }
- }
- }
- ?>
コードをコピー
2.サーバーパフォーマンスデータのget_used_statusファイル。
-
-
/** - * サーバーのパフォーマンス CPU、メモリ、ハードディスク、その他の使用率を取得します
- * bbs.it-home.org を編集します
- */
- /*接続データ開始*/
- 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($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);
-
- /*IP アドレスの取得 begin*/
- /*
- $fp = Popen('ifconfig eth0 | grep -E "(inet addr)"','r');
- $rs = fread($fp,1024);
- pclose($fp);
- $rs = preg_replace("/s{2,}/",' ',trim($rs)); //複数のスペースを " _" に置き換えます
- $rs =explode(" " ,$rs);
- $ip = trim($rs[1],'addr:');
- */
- /*IP アドレスの取得end*/
- /*
- $ file_name = "/tmp/data.txt"; // 絶対パス: homedata.dat
- $file_pointer = fopen($file_name, "a+") // "w" はモードです、詳細については以下を参照してください
- fwrite($ file_pointer,$ip); // 最初にファイルを 0 バイトに書き込み、
- fclose($file_pointer); // 終了
- */
-
- 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( ))."
";
-
- $status=get_used_status();
-
- $sql = "パフォーマンスに挿入(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) または die("SQL ステートメントの実行に失敗しました!");
- unset($status);
-
- //echo date("Y-m-d H :i:s",time())."
?>
-
コードをコピー
|