看到有人寫(xiě)透視寶做php監(jiān)控的原理圖,跟你分享下。我估計(jì)大家做的方式都是差不多。
成都創(chuàng)新互聯(lián)從2013年成立,先為西平等服務(wù)建站,西平等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢(xún)服務(wù)。為西平企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
PHP運(yùn)行支撐的ZendEngine早在設(shè)計(jì)過(guò)程中已經(jīng)預(yù)留了豐富的Hook,可以有效干涉處理過(guò)程中的幾個(gè)關(guān)鍵步驟。利用了以下幾個(gè)Hook,就能方便的獲取數(shù)據(jù):
1. ? ? ? ? ? zend_compile_file zend_compile_string
加載分析文件或字符串,本身就會(huì)造成非常大的IO,如果過(guò)多地執(zhí)行加載,無(wú)疑會(huì)造成內(nèi)存和CPU的消耗.通過(guò)這兩個(gè)hook,可以取得文件名、執(zhí)行行數(shù)、使用內(nèi)存和CPU占用時(shí)間。
2.???????????zend_execute zend_execute_internal
通過(guò)這兩個(gè)hook的使用,我們可以準(zhǔn)確地分析得出一個(gè)PHP應(yīng)用中的類(lèi)調(diào)用、方法調(diào)用、方法參數(shù)、內(nèi)存占用和CPU占用,加以分析,便可以準(zhǔn)確得出應(yīng)用系統(tǒng)運(yùn)行過(guò)程中的方法運(yùn)行棧,API調(diào)用地址,SQL語(yǔ)句,CacheKey以及Cache命中等關(guān)鍵信息。
3.???????????zend_throw_exception_hook
利用異常鉤子,可以準(zhǔn)確地得到應(yīng)用系統(tǒng)運(yùn)行過(guò)程中出現(xiàn)的異常信息,當(dāng)然包括異常發(fā)生的類(lèi)\方法位置,參數(shù),異常code和異常message。
4.???????????zend_error_cb
錯(cuò)誤鉤子則更加直接,可以準(zhǔn)確得到系統(tǒng)運(yùn)行過(guò)程中出現(xiàn)的任何一個(gè)warning,代碼錯(cuò)誤或語(yǔ)法錯(cuò)誤。
在服務(wù)端建立一個(gè)根據(jù)需要進(jìn)行循環(huán)的PHP腳本就可以。
猜測(cè)一下,您的第二個(gè)問(wèn)題,是不是想進(jìn)行相關(guān)檢測(cè)以避免重復(fù)觸發(fā)這個(gè)腳本。
實(shí)際上,不建議由用戶(hù)行為觸發(fā)這個(gè)腳本,無(wú)論是服務(wù)端代碼,還是客戶(hù)端的異步Ajax。
如果要用PHP腳本進(jìn)行不停的循環(huán)監(jiān)控,請(qǐng)聯(lián)系運(yùn)維人員,服務(wù)器啟動(dòng),即在服務(wù)端開(kāi)始運(yùn)行這個(gè)腳本,他們會(huì)向您提供解決方案的。
真正的建議是,如果有任何可能,都不要使用PHP腳本利用循環(huán)代碼進(jìn)行服務(wù)端的監(jiān)控。
不得不承認(rèn),這個(gè)方面PHP的穩(wěn)定性還差一些,Java或許可以這么做,PHP就比較痛苦了。
比較可能的辦法是請(qǐng)運(yùn)維人員幫忙,通報(bào)監(jiān)控邏輯,然后請(qǐng)他安裝各種觸發(fā)條件調(diào)用相應(yīng)的PHP代碼。
如果堅(jiān)持使用PHP腳本進(jìn)行相關(guān)工作,有兩個(gè)建議給您:
盡快釋放資源,無(wú)論腳本使用了什么資源,包括文件、內(nèi)存、數(shù)據(jù)庫(kù)等等,都盡快釋放,這種地方可萬(wàn)萬(wàn)不能偷懶,否則就是自虐了。
在這個(gè)腳本中進(jìn)行獨(dú)立的手工日志輸出,任何一層循環(huán)的入口都要進(jìn)行記錄,這樣在監(jiān)控失敗的時(shí)候才有辦法查找問(wèn)題。
那你可以在插入數(shù)據(jù)庫(kù)那里設(shè)置監(jiān)聽(tīng)呀,一有插入就往Android推送消息。
不然你只能通過(guò)每隔一段時(shí)間刷新一下讀取數(shù)據(jù)庫(kù),看看有沒(méi)有更新,有就推送,沒(méi)有就繼續(xù)監(jiān)聽(tīng),這個(gè)你可以自己設(shè)置更新時(shí)間。
1,Linux下可以在/proc/cpuinfo中看到每個(gè)cpu的詳細(xì)信息。但是對(duì)于雙核的cpu,在cpuinfo中會(huì)看到兩個(gè)cpu。常常會(huì)讓人誤以為是兩個(gè)單核的cpu。
其實(shí)應(yīng)該通過(guò)Physical
Processor
ID來(lái)區(qū)分單核和雙核。而Physical
Processor
ID可以從cpuinfo或者dmesg中找到.
flags
如果有
ht
說(shuō)明
支持超線(xiàn)程技術(shù)
判斷物理CPU的個(gè)數(shù)可以查看physical
id
的值,相同則為同一個(gè)物理CPU
2,查看內(nèi)存大小:
cat
/proc/meminfo
|grep
MemTotal
3,其他一些可以查看詳細(xì)
linux系統(tǒng)
信息的命令和方法:
uname
-a
#
查看內(nèi)核/操作系統(tǒng)/
CPU信息
的linux系統(tǒng)信息命令
head
-n
1
/etc/issue
#
查看操作系統(tǒng)版本,是數(shù)字1不是字母L
cat
/proc/cpuinfo
#
查看CPU信息的linux系統(tǒng)信息命令
hostname
#
查看計(jì)算機(jī)名的linux系統(tǒng)信息命令
lspci
-tv
#
列出所有
PCI設(shè)備
lsusb
-tv
#
列出所有USB設(shè)備的linux系統(tǒng)信息命令
lsmod
#
列出加載的內(nèi)核模塊
env
#
查看
環(huán)境變量
資源
free
-m
#
查看內(nèi)存使用量和
交換區(qū)
使用量
df
-h
#
查看各分區(qū)使用情況
du
-sh
#
查看指定目錄的大小
grep
MemTotal
/proc/meminfo
#
查看內(nèi)存總量
grep
MemFree
/proc/meminfo
#
查看空閑內(nèi)存量
uptime
#
查看系統(tǒng)
運(yùn)行時(shí)間
、用戶(hù)數(shù)、負(fù)載
cat
/proc/loadavg
#
查看系統(tǒng)負(fù)載磁盤(pán)和分區(qū)
mount
|
column
-t
#
查看掛接的分區(qū)狀態(tài)
fdisk
-l
#
查看所有分區(qū)
swapon
-s
#
查看所有
交換分區(qū)
hdparm
-i
/dev/hda
#
查看磁盤(pán)參數(shù)(僅適用于
IDE設(shè)備
)
dmesg
|
grep
IDE
#
查看啟動(dòng)時(shí)IDE設(shè)備檢測(cè)狀況網(wǎng)絡(luò)
ifconfig
#
查看所有網(wǎng)絡(luò)接口的屬性
iptables
-L
#
查看防火墻設(shè)置
route
-n
#
查看
路由表
netstat
-lntp
#
查看所有監(jiān)聽(tīng)端口
netstat
-antp
#
查看所有已經(jīng)建立的連接
netstat
-s
#
查看
網(wǎng)絡(luò)統(tǒng)計(jì)
信息進(jìn)程
ps
-ef
#
查看所有進(jìn)程
top
#
實(shí)時(shí)顯示
進(jìn)程狀態(tài)
用戶(hù)
w
#
查看活動(dòng)用戶(hù)
id
#
查看指定用戶(hù)信息
last
#
查看
用戶(hù)登錄
日志
cut
-d:
-f1
/etc/passwd
#
查看系統(tǒng)所有用戶(hù)
cut
-d:
-f1
/etc/group
#
查看系統(tǒng)所有組
crontab
-l
#
查看當(dāng)前用戶(hù)的計(jì)劃任務(wù)服務(wù)
chkconfig
–list
#
列出所有系統(tǒng)服務(wù)
chkconfig
–list
|
grep
on
#
列出所有啟動(dòng)的系統(tǒng)服務(wù)程序
rpm
-qa
#
查看所有安裝的軟件包
cat
/proc/cpuinfo
:查看CPU相關(guān)參數(shù)的linux系統(tǒng)命令
cat
/proc/partitions
:查看linux硬盤(pán)和分區(qū)信息的系統(tǒng)信息命令
cat
/proc/meminfo
:查看linux系統(tǒng)內(nèi)存信息的linux系統(tǒng)命令
cat
/proc/version
:查看版本,類(lèi)似uname
-r
cat
/proc/ioports
:查看設(shè)備io端口
cat
/proc/interrupts
:查看中斷
cat
/proc/pci
:查看pci設(shè)備的信息
cat
/proc/swaps
:查看所有swap分區(qū)的信息
最好的辦法是,在應(yīng)用程序生命周期內(nèi),對(duì)于數(shù)據(jù)庫(kù)設(shè)置有事件鉤子,用于監(jiān)聽(tīng)程序?qū)τ跀?shù)據(jù)庫(kù)的操作。這樣非常方便處理邏輯流程。
1 - 表的數(shù)據(jù)變化
表數(shù)據(jù)發(fā)生了變化,毫無(wú)疑問(wèn)是寫(xiě)操作,包括以下幾種情形:
新建條目 create
更新條目 update
刪除條目 delete
以上三種都是寫(xiě)操作,會(huì)對(duì)表數(shù)據(jù)寫(xiě)入。
2 - 事件鉤子
既然需要實(shí)時(shí)監(jiān)控,那么每個(gè)數(shù)據(jù)庫(kù)的操作,都需要考慮在內(nèi),這是全局的監(jiān)聽(tīng)。
以laravel的Eloquent ORM 模型觸發(fā)事件,允許你掛接到模型生命周期的如下節(jié)點(diǎn): retrieved、creating、created、updating、updated、saving、saved、deleting、deleted、restoring 和 restored。事件允許你每當(dāng)特定模型保存或更新數(shù)據(jù)庫(kù)時(shí)執(zhí)行代碼。每個(gè)事件通過(guò)其構(gòu)造器接受模型實(shí)例。
模型內(nèi)添加事件監(jiān)聽(tīng)鉤子
如果重用率很高,那么使用觀察者 Observer 方式進(jìn)行監(jiān)聽(tīng)更為高效。
Laravel Observer
結(jié)語(yǔ)
上面的方法要求讀者有l(wèi)aravel框架的使用基礎(chǔ),對(duì)于構(gòu)建中大型應(yīng)用非常有利。