国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHP滾動日志的代碼實現

2024-05-04 23:36:02
字體:
來源:轉載
供稿:網友

所謂滾動日志,顧名思義,就是記錄一個模塊的日志用一系列的日志文件,同一模塊文件個數有限制,最多maxNum個,大小也有限制,最大maxSize字節,文件名有一定的命名方式,比如:testlog.log、testlog_1.log,testlog_2.log、、、、、、

PHP滾動日志類庫

PHP記錄日志,我之前接觸過的有按照年月分文件夾,然后按照日分文件的日志記錄方式,這種方式有利有弊,有他的使用場景,我今天要說的是另一種日志記錄方式——文件滾動方式記錄日志,當然了,這種滾動機制也可以加在前面那種日志記錄方式中。

如何讓日志滾動起來

滾動日志,顧名思義,記錄一個模塊的日志用一系列的日志文件,同一模塊文件個數有限制,最多maxNum個,大小也有限制,最大maxSize字節,文件名有一定的命名方式,比如:testlog.log、testlog_1.log,testlog_2.log、、、、、、其中testlog.log是正在使用的日志文件,當testlog.log文件大小到達限制maxSize的時候就會向后滾動日志文件,就像下面這樣:

代碼如下:

testlog_2.log  -> testlog_3.log
testlog_1.log  -> testlog_2.log
testlog.log  -> testlog_1.log
testlog.log #0kb

當日志文件個數到達限制maxNum的時候就會啟動淘汰機制,刪除最老的日志,比如說maxNum設置為10,這個時候算上testlog.log一共最多有10個文件,當滾動的時候如果存在testlog_9.log就會從testlog_8.log開始滾動,覆蓋掉testlog_9.log,這樣就可以保證日志正常記錄,而且不會出現很大很大的日志文件,保證日志系統的正常運行。

代碼實現

 

 
  1. <?php 
  2. final class LOGS { 
  3. private $level
  4. private $maxFileNum
  5. private $maxFileSize
  6. private $logPath
  7. private $file
  8.  
  9. //日志的級別DEBUG,MSG,ERR 
  10. const LOGS_DEBUG = 0; 
  11. const LOGS_MSG = 1; 
  12. const LOGS_ERR = 2; 
  13.  
  14. private static $instance = null; 
  15.  
  16. private function __construct(){} 
  17.  
  18. public static function getInstance() 
  19. if(self::$instance == null) 
  20. self::$instance = new self(); 
  21. return self::$instance
  22.  
  23. /** 
  24. * @Desc 初始化 
  25. * @Param $level int 記錄級別 
  26. * @Param $maxNum int 最大日志文件數目 
  27. * @Param $maxSize int 最大日志文件大小 
  28. * @Param $logPath string 日志文件保存路徑 
  29. * @Param $file string 日志文件名稱前綴 
  30. * @Return boolean 
  31. */ 
  32. public function init($level$maxNum$maxSize$logPath$file
  33. $level = intval($level); 
  34. $maxNum = intval($maxNum); 
  35. $maxSize = intval($maxSize); 
  36. !is_dir($logPath) && mkdir($logPath, 0777, true); 
  37. if(!in_array($levelarray(self::LOGS_DEBUG, self::LOGS_MSG, self::LOGS_ERR)) || $maxNum <= 0 || $maxSize <= 0 || !is_dir($logPath)) 
  38. return false; 
  39. $this->level = $level
  40. $this->maxFileNum = $maxNum
  41. $this->maxFileSize = $maxSize
  42. $this->logPath = $logPath
  43. $this->file = $file
  44. return true; 
  45.  
  46. /** 
  47. * @Desc 獲取格式化時間串 
  48. */ 
  49. public function formatTime() 
  50. $ustime = explode ( " ", microtime () ); 
  51. return "[" . date('Y-m-d H:i:s', time()) .".". ($ustime[0] * 1000) . "]"
  52.  
  53. /**  
  54. * @Desc 滾動方式記錄日志文件 
  55. */ 
  56. public function log($str
  57. $path = $this->logPath.DIRECTORY_SEPARATOR.$this->file.".log"
  58. clearstatcache(); 
  59. if(file_exists($path)) 
  60. if(filesize($path) >= $this->maxFileSize) 
  61. $index = 1; 
  62. //獲取最大的滾動日志數目 
  63. for(;$index < $this->maxFileNum; $index++) 
  64. if(!file_exists($this->logPath.DIRECTORY_SEPARATOR.$this->file."_".$index.".log")) 
  65. break
  66. //已經存在maxFileNum個日志文件了 
  67. if($index == $this->maxFileNum) 
  68. $index--; 
  69. //滾動日志 
  70. for(;$index > 1; $index--) 
  71. $new = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_".$index.".log"
  72. $old = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_".($index - 1).".log"
  73. rename($old$new); 
  74.  
  75. $newFile = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_1.log"
  76. rename($path$newFile); 
  77. $fp = fopen($path"a+b"); 
  78. fwrite($fp$strstrlen($str)); 
  79. fclose($fp); 
  80. return true; 
  81.  
  82. /** 
  83. * @Desc 記錄調試信息 
  84. * @Param string 日志信息 
  85. * @Param string 日志所在文件 
  86. * @Param string 日志所在行 
  87. */ 
  88. public function debug($msg$file$line
  89. if($this->level <= self::LOGS_DEBUG) 
  90. $this->log($this->formatTime()."[{$file}:{$line}]DEBUG: ${msg}/n"); 
  91.  
  92. /** 
  93. * @Desc 記錄信息 
  94. * @Param string 日志信息 
  95. * @Param string 日志所在文件 
  96. * @Param string 日志所在行 
  97. */ 
  98. public function msg($msg$file$line
  99. if($this->level <= self::LOGS_MSG) 
  100. $this->log($this->formatTime()."[{$file}:{$line}]MSG: ${msg}/n"); 
  101.  
  102. /** 
  103. * @Desc 記錄錯誤信息 
  104. * @Param string 日志信息 
  105. * @Param string 日志所在文件 
  106. * @Param string 日志所在行 
  107. */ 
  108. public function err($msg$file$line
  109. if($this->level <= self::LOGS_ERR) 
  110. $this->log($this->formatTime()."[{$file}:{$line}]ERR: ${msg}/n"); 

看個例子

#例子中設置記錄級別為msg(此時debug信息是不會紀錄的),日志文件個數為5,大小為200個字節(測試方便),文件名稱為testlog

 

 
  1. $logs = LOGS::getInstance(); 
  2. $logs->init(1, 5, 200, "./"'testlog'); 
  3.  
  4. $logs->msg("YRT"__FILE____LINE__); 
  5. $logs->debug("YRT"__FILE____LINE__); 

當我們不停的運行這個例子的時候,會在代碼所在文件夾下生成5個文件就像下面這樣:

 

 
  1. testlog_4.log 
  2. testlog_3.log 
  3. testlog_2.log 
  4. testlog_1.log 
  5. testlog.log #最新的日志在這個文件中 

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 咸宁市| 嫩江县| 汉沽区| 闻喜县| 固阳县| 常熟市| 澄城县| 外汇| 南阳市| 蚌埠市| 普洱| 九台市| 枣阳市| 云安县| 呼和浩特市| 清水河县| 柳江县| 体育| 景宁| 石泉县| 涪陵区| 荆门市| 苗栗市| 清水河县| 确山县| 平阴县| 崇文区| 怀集县| 长武县| 永年县| 瑞昌市| 邵东县| 忻城县| 水富县| 都兰县| 文昌市| 邯郸县| 娄烦县| 新泰市| 施秉县| 清苑县|