一、PHP 垃圾回收機制(Garbage Collector 簡稱GC)
在PHP中,沒有任何變量指向這個對象時,這個對象就成為垃圾。PHP會將其在內存中銷毀;這是PHP的GC垃圾處理機制,防止內存溢出。
當一個PHP線程結束時,當前占用的所有內存空間都會被銷毀,當前程序中所有對象同時被銷毀。GC進程一般都跟著每起一個SESSION而開始運行的.gc目的是為了在session文件過期以后自動銷毀刪除這些文件.
二、__destruct /unset
__destruct() 析構函數(shù),是在垃圾對象被回收時執(zhí)行。
unset 銷毀的是指向對象的變量,而不是這個對象。
三、 Session 與PHP垃圾回收機制
由于PHP的工作機制,它并沒有一個daemon線程來定期的掃描Session信息并判斷其是否失效,當一個有效的請求發(fā)生時,PHP 會根據(jù)全局變量 session.gc_probability和session.gc_divisor的值,來決定是否啟用一個GC, 在默認情況下,session.gc_probability=1, session.gc_divisor =100也就是說有1%的可能性啟動GC(也就是說100個請求中只有一個gc會伴隨100個中的某個請求而啟動).
PHP垃圾回收機制的工作就是掃描所有的Session信息,用當前時間減去session最后修改的時間,同session.gc_maxlifetime參數(shù)進行比較,如果生存時間超過gc_maxlifetime(默認24分鐘),就將該session刪除。
但是,如果你Web服務器有多個站點,多個站點時,GC處理session可能會出現(xiàn)意想不到的結果,原因就是:GC在工作時,并不會區(qū)分不同站點的session.
那么這個時候怎么解決呢?
修改session.save_path,或使用session_save_path()讓每個站點的session保存到一個專用目錄,
-
提供GC的啟動率,自然,PHP垃圾回收機制的啟動率提高,系統(tǒng)的性能也會相應減低,不推薦。
- 在代碼中判斷當前session的生存時間,利用session_destroy()刪除.
PHP的內存管理, 分為倆大部分, 第一部分是PHP自身的內存管理, 這部分主要的內容就是引用計數(shù), 寫時復制, 等等面向應用的層面的管理. 而第二部分是 zend_alloc中描寫的關于PHP自身的內存管理, 包括它是如何管理可用內存, 如何分配內存等.
Zend Memory Manager, 以下簡稱Zend MM, 是PHP中內存管理的邏輯. 其中有一個關鍵數(shù)據(jù)結構: zend_mm_heap
Zend MM把內存分為小塊內存和大塊內存?zhèn)z種, 區(qū)別對待, 對于小塊內存, 這部分是最最常用的, 所以追求高性能. 而對于大塊內存, 則追求的是穩(wěn)妥, 盡量避免內存浪費.
所以, 對于小塊內存, PHP還引入了cache機制,Zend MM 希望通過cache盡量做到, 一次定位就能查找分配.