php實(shí)現(xiàn)監(jiān)控varnish緩存服務(wù)器的狀態(tài)
當(dāng)varnish和網(wǎng)站部署在同一臺(tái)服務(wù)器上的時(shí)候,我們不可能隨時(shí)登錄上服務(wù)器去查看varnish的命中率,沒(méi)想到有大神早就寫了出來(lái),今天就分享給大家,使用網(wǎng)頁(yè)查看varnish命中率。
系統(tǒng):centos 5.x
軟件:varnish-3.0.x
ps:3.0以下的版本可以通過(guò)Socket連接到Varnish管理端口,通過(guò)stat命令查看,3.0以上沒(méi)有stat命令,只能通過(guò)下面的方法解決。
<?php
$outfile=shell_exec("/usr/bin/varnishstat -x");
$xml=simplexml_load_string($outfile);
echo $xml->getName() . "<br />";
foreach($xml->children() as $child)
{
//$tmpName="";
foreach($child->children() as $subChild)
{
if ($subChild->getName() =="name" )
{
$tmpName=$subChild;
}
else if ($subChild->getName() =="value" )
{
if ($tmpName!="")
{
$arys["$tmpName"]=$subChild;
$tmpName="";
}
}
else
{
continue;
}
}
}
function byteReduce($bytes)
{
if ($bytes>1099511627776)
{
return round($bytes/1099511627776)."TB";
}
else if ($bytes > 1073741824)
{
return round($bytes/1073741824)."GB";
}
else if ($bytes>1048576)
{
return round($bytes/1048576)."MB";
}
else if ($bytes>1024)
{
return round($bytes/1024)."KB";
}
else
{
return $bytes."B";
}
}
echo "client_conn: ".$arys["client_conn"] . "<br />";
echo "client_req: ".$arys["client_req"] . "<br />";
echo "cache_hit: ".$arys["cache_hit"] . "<br />";
echo "cache_miss: ".$arys["cache_miss"] . "<br />";
echo "Cache hit rate: ".round(($arys["cache_hit"]/$arys["client_req"])*100)." % <br/>";
echo "LRU nuked objects: ".$arys[n_lru_nuked]."<br/>";
echo " ".byteReduce($arys["s_bodybytes"]+$arys["s_hdrbytes"])." Acc Content (".byteReduce($arys["s_hdrbytes"])." header ".byteReduce($arys["s_bodybytes"])." Body)";
?>
效果如下:
ps:為了查看實(shí)時(shí)情況,可以在這監(jiān)控頁(yè)加個(gè)html定時(shí)刷新.
好了,這樣就方便我們隨時(shí)查看varnish的狀態(tài)了.
- PHP實(shí)現(xiàn)服務(wù)器狀態(tài)監(jiān)控的方法
- PHP-FPM運(yùn)行狀態(tài)的實(shí)時(shí)查看及監(jiān)控詳解
- PHP腳本監(jiān)控Nginx 502錯(cuò)誤并自動(dòng)重啟php-fpm
- 實(shí)現(xiàn)Nginx中使用PHP-FPM時(shí)記錄PHP錯(cuò)誤日志的配置方法
- nginx php-fpm中啟用慢日志配置(用于檢測(cè)執(zhí)行較慢的PHP腳本)
- PHP連接Nginx服務(wù)器并解析Nginx日志的方法
- PHP統(tǒng)計(jì)nginx訪問(wèn)日志中的搜索引擎抓取404鏈接頁(yè)面路徑
- PHP記錄和讀取JSON格式日志文件
- 全面解讀PHP的Yii框架中的日志功能
- PHP簡(jiǎn)單實(shí)現(xiàn)定時(shí)監(jiān)控nginx日志文件功能示例
相關(guān)文章
php實(shí)現(xiàn)帶讀寫分離功能的MySQL類完整實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)帶讀寫分離功能的MySQL類,具有針對(duì)mysql數(shù)據(jù)庫(kù)的基本增刪改查及讀寫分離操作的功能,涉及針對(duì)讀庫(kù)與寫庫(kù)的判斷及操作技巧,需要的朋友可以參考下2016-07-07php使用QueryList輕松采集js動(dòng)態(tài)渲染頁(yè)面方法
這篇文章給大家分享了php使用QueryList輕松采集js動(dòng)態(tài)渲染頁(yè)面的相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友學(xué)習(xí)下。2018-09-09將酷狗krc歌詞解析并轉(zhuǎn)換為lrc歌詞php源碼
這篇文章主要介紹了krc歌詞解析并轉(zhuǎn)換為lrc歌詞的php實(shí)現(xiàn)方法,需要的朋友可以參考下2014-06-06關(guān)于初學(xué)PHP時(shí)的知識(shí)積累總結(jié)
本篇文章筆者初學(xué)PHP時(shí)的一些知識(shí)積累經(jīng)驗(yàn),需要的朋友參考下2013-06-06PHP simple_html_dom.php+正則 采集文章代碼
網(wǎng)上也有很多人也在用PHP Simple Dom 雖然效率慢了點(diǎn),但效果還是不錯(cuò)的從包含類庫(kù)文件到寫入txt文件 大概是7/8就秒。2009-12-12