当前位置: 首页 > 后端技术 > PHP

PHP内存泄漏原因分析及垃圾回收机制探讨

时间:2023-03-30 05:30:36 PHP

鏈€杩戝湪鍐欒剼鏈殑鏃跺€欙紝寰幆涓弽澶嶈皟鐢ㄦ煇涓柟娉曘€傛寜鐓у墠闈㈢殑鐞嗚В锛屾柟娉曟墽琛屽畬鎴愬悗锛屽眬閮ㄥ彉閲忓氨澶辨晥浜嗭紝瀹冪敵璇风殑鍐呭瓨灏辫閲婃斁浜嗭紝浣嗕簨瀹炲苟闈炲姝ゃ€??phpclassFoo{public$var='3.1415962654';}$baseMemory=memory_get_usage();for($i=0;$i<=100000;$i++){f($i,$baseMemory);}鍑芥暟f($i,$baseMemory){$a=newFoo;$a->self=$a;if($i%500===0){echosprintf('%8d:',$i),memory_get_usage()-$baseMemory,"\n";}}}杩愯涓婇潰浠g爜鍚庡彂鐜帮紝PHP鍐呭瓨鍦ㄧ寮€鍑芥暟鍚庡苟娌℃湁閲婃斁锛岃€屾槸鍦ㄨ揪鍒颁竴瀹氬€煎悗鎵嶄細閲婃斁锛坧hp5.3浠ュ悗鎵嶈璁烘満鍒讹級銆傚畼鏂圭殑璇存硶鏄紝棣栧厛锛屽疄鏂藉瀮鍦惧洖鏀剁殑鍏ㄩ儴鍘熷洜鏄€氳繃鍦ㄦ弧瓒冲厛鍐虫潯浠跺悗娓呯悊寰幆寮曠敤鐨勫彉閲忔潵鑺傜渷鍐呭瓨鍗犵敤銆傚湪PHP鎵ц涓紝涓€鏃︽牴缂撳啿鍖哄凡婊℃垨璋冪敤gc_collect_cycles()鍑芥暟鏃讹紝灏变細鎵ц鍨冨溇鏀堕泦銆備篃灏辨槸璇达紝鍙鏍圭紦鍐插尯婊′簡锛孭HP灏变細杩涜鍨冨溇鍥炴敹锛岄噴鏀炬湭浣跨敤鐨勫唴瀛樸€傞偅涔堜粈涔堟槸鈥滄牴缂撳啿鍖衡€濓紵鏍圭紦鍐插尯鏄竴涓鍣紝鐢ㄦ潵瀛樻斁鎵€鏈夊彲鑳界殑鏍癸紙鍙互鐞嗚В涓簆hp涓殑鍙橀噺锛夈€傚畠鐨勫€间负10000锛屽彲浠ヤ慨鏀筆HP婧愭枃浠禯end/zend_gc.c涓殑甯搁噺GC_ROOT_BUFFER_MAX_ENTRIES锛岀劧鍚庨噸鏂扮紪璇慞HP淇敼杩欎釜10000鐨勫€笺€傚鏋滀綘娌℃湁淇敼杩噐ootbuffer鐨勫€硷紝瑙傚療涓婇潰鐨勪唬鐮侊紝浣犱細鍙戠幇姣?0000娆″氨浼氳繘琛屼竴娆″瀮鍦惧洖鏀讹紝涔熷氨鏄10000娆″~鍏卹ootbuffer銆傞偅涔堥棶棰樻潵浜嗐€傚鏋滄垜鐨勫崟涓彉閲忓崰鐢ㄥ唴瀛樺ぇ锛宺ootbuffer杩樻病婊★紝鍙兘鍐呭瓨灏辩敤瀹屼簡锛屽啀鍒嗛厤鍐呭瓨灏辨潵涓嶅強浜嗐€傝繖鏄彲鑳藉鑷村唴瀛樻硠婕忕殑鍘熷洜涔嬩竴銆?渚嬪涓嬮潰鐨勪緥瀛??phpini_set('memory_limit','128M');classUse10MClass{public$var=null;鍏叡鍑芥暟__construct(){$this->var=str_pad('1',10*1024*1024);}}$baseMemory=memory_get_usage();echo"褰撳墠鍐呭瓨:",memory_get_usage(),"\n";for($i=0;$i<=100;$i++){test($i,$baseMemory);}鍑芥暟娴嬭瘯($i,$baseMemory){$b=newUse10MClass();$b->self=$b;echosprintf('%8d:',$i),memory_get_usage()-$baseMemory,"\n";}鍦ㄧ鍗佷竴涓惊鐜腑锛屾姤PHPFatalerror:Allowedmemorysizeof134217728bytesexhausted(triedtoallocate10485785bytes)杩欎釜閿欒锛岀敱浜庡崟涓彉閲忔秷鑰楃殑鍐呭瓨杩囧锛宺ootbuffer鍖哄煙鍙~婊′簡11锛岃繕娌℃潵寰楀強杩涜鍨冨溇鍥炴敹锛屽唴瀛樺氨鐖嗕簡銆傛湁涓や釜涓板瘜鑰屽己澶х殑瑙e喅鏂规锛岀洿鎺ュ鍔犲垎閰嶇殑鍐呭瓨馃惗銆備絾鏄紝杩欑鏂规硶涓€鑸敤浜庣揣鎬ユ儏鍐典笅浣跨敤銆傚洜涓哄唴瀛樻硠婕忥紝鍩烘湰涓婂氨鎰忓懗鐫€绋嬪簭鍑虹幇浜嗕竴浜涢棶棰樸€傛渶濂芥壘鍒板唴瀛樺崰鐢ㄨ繃澶氱殑鍘熷洜銆傚湪閫傚綋鐨勬椂鍊欒皟鐢╣c_collect_cycles()涓诲姩杩涜鍨冨溇鍥炴敹锛岄噴鏀惧浣欑殑绌洪棿銆傛墍浠ヤ笂闈唬鐮佹渶濂界殑瑙e喅鍔炴硶灏辨槸姣忛殧涓€娈垫椂闂存墜鍔ㄨ繘琛屼竴娆″瀮鍦惧洖鏀躲€傝繖鏍风▼搴忓氨鍙互椤哄埄杩愯浜嗐€??phpini_set('memory_limit','128M');classUse10MClass{public$var=null;鍏叡鍑芥暟__construct(){$this->var=str_pad('1',10*1024*1024);}}$baseMemory=memory_get_usage();echo"褰撳墠鍐呭瓨:",memory_get_usage(),"\n";for($i=0;$i<=100;$i++){test($i,$baseMemory);//姣忓叓娆℃墽琛屼竴娆″瀮鍦惧洖鏀秈f($i%8===0){gc_collect_cycles();}}鍑芥暟娴嬭瘯($i,$baseMemory){$b=newUse10MClass();$b->self=$b;echosprintf('%8d:',$i),memory_get_usage()-$baseMemory,"\n";}鍙﹀unset鍙橀噺涓嶄細椹笂閲婃斁鍐呭瓨锛岃婧㈠嚭鐨勬椂鍊欒繕鏄細婧㈠嚭銆傚湪鍑芥暟鐨勬渶鍚庝竴鍙ュ彇娑堣缃眬閮ㄥ彉閲忔槸娌℃湁鎰忎箟鐨勩€備竴鑸潵璇达紝鍙橀噺铏界劧涓嶈兘浣跨敤锛屼絾鏄畠鎵€鍗犵敤鐨勫唴瀛樼┖闂存槸涓嶄細琚崰鐢ㄧ殑銆備竴鑸▼搴忕瓑寰卹ootbuffer婊′簡锛岃嚜鍔ㄥ瀮鍦惧洖鏀跺氨鍙互浜嗐€備絾鏄浜庝竴浜涘彉閲忔瘮杈冨ぇ鐨勬儏鍐碉紝鍙互鍦ㄥ悎閫傜殑鏃跺€欐墽琛実c_collect_cycles()涓诲姩杩涜鍨冨溇鍥炴敹锛岄伩鍏嶅唴瀛樻硠闇层€傜▼搴忚繘琛屽瀮鍦惧洖鏀堕渶瑕佷竴瀹氱殑鏃堕棿锛屾墍浠ヤ笉寤鸿棰戠箒璋冪敤gc_collect_cycles()銆?/p>

最新推荐
猜你喜欢