[ 1880957.563400] Out of memory: Kill process 18694(perl) score 246or sacrifice child
[ 1880957.563408] Killed process 18694(perl) total-vm: 1972392kB, anon-rss: 1953348kB, file-rss: 0kB
[ 2320864.954447] TCP: Possible SYN flooding onport 7001.Dropping request. Check SNMP counters .123456
打印內(nèi)核環(huán)形緩存區(qū)中的內(nèi)容,可以用來查看一些錯誤;
section 4:動態(tài)內(nèi)存分配進(jìn)階 深入理解動態(tài)分配內(nèi)存的內(nèi)部機(jī)制 堆和棧 代碼段 數(shù)據(jù)段 環(huán)境變量和命令行參數(shù) 棧 堆 進(jìn)程地址空間 malloc函數(shù)的機(jī)制 分配原則——最先適合分配方法 malloc內(nèi)部調(diào)用sbrk 系統(tǒng)調(diào)用 一個進(jìn)程使用一個堆,所有內(nèi)存由操作系統(tǒng)管理 問題:如果申請一個內(nèi)存并沒有釋放,當(dāng)進(jìn)程結(jié)束運(yùn)行的時(shí)候,會造成內(nèi)存泄露么嗎。
系統(tǒng)內(nèi)存余量大小 (mem.memfree):redis是純內(nèi)存系統(tǒng),系統(tǒng)內(nèi)存必須保有足夠余量,避免出現(xiàn)oom,導(dǎo)致redis進(jìn)程被殺,或使用swap導(dǎo)致redis性能驟降。
3.解析chunktype為covr的越界以及溢出當(dāng)chunk_data_size小于kskipbytesofdatabox會造成underflow,傳給setdata會越界讀同一個地方當(dāng)chunk_data_size等于size_max,可以導(dǎo)致整數(shù)溢出,后面的readat操作會繼續(xù)讀寫操作,導(dǎo)致寫越界.。
通過這個措施,便可以避免攻擊數(shù)據(jù)包到達(dá)上層或者被forward到其它網(wǎng)段,有效為后面的處理邏輯屏蔽了不必要的內(nèi)存消耗以及cpu時(shí)間的浪費(fèi)。
3. vmstat 1$ vmstat 1
procs ---------memory---------- ---swap-- -----io---- -system-- ------cpu-----
r b swpd free buff cachesi so bi bo incs us sy idwa st
3400200889792737085918280005610961300
320020088992073708591860000592132844282981100
320020089011273708591860000095012154991000
32002008895687371259185600048119002459990000
3200200890208737125918600000158984840981100
^C123456789
打印進(jìn)程、內(nèi)存、交換分區(qū)、IO和CPU等的統(tǒng)計(jì)信息;
vmstat的格式如下
> vmstat[options][delay [count]]
vmstat第一次輸出表示從開機(jī)到vmstat運(yùn)行時(shí)的平均值;剩余輸出的都是在指定的時(shí)間間隔內(nèi)的平均值,上述例子中delay的值設(shè)置為1,除第一次以外,剩余的都是1秒統(tǒng)計(jì)一次,count未設(shè)置,將會一直循環(huán)打印。
$ vmstat 10 3
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
r b swpd free buff cachesi so bi bo incs us sy idwa st