亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 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 #最新的日志在這個文件中 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
韩国国内大量揄拍精品视频| 色妞一区二区三区| 亚洲精品视频久久| 久久精品视频中文字幕| 最近2019中文字幕在线高清| 亚洲国产成人精品久久久国产成人一区| 欧美日韩国产一区在线| 亚洲欧美日韩爽爽影院| 国产精品久久久久免费a∨| 欧美不卡视频一区发布| 欧美在线视频一区二区| 色香阁99久久精品久久久| 精品国产电影一区| 精品国产依人香蕉在线精品| 日韩av手机在线| 国产成人精品综合久久久| 国产精品亚洲欧美导航| 亚洲成人精品久久| 日韩电影中文字幕| 奇米影视亚洲狠狠色| 久久av资源网站| 国产精品一香蕉国产线看观看| 亚洲福利视频久久| 91国语精品自产拍在线观看性色| 欧美成人精品影院| 精品国产乱码久久久久久天美| 一区二区欧美激情| 久久亚洲国产精品| 久久综合久久八八| 久久琪琪电影院| 欧美做受高潮电影o| 成人黄色午夜影院| 亚洲国产欧美一区二区三区同亚洲| 亚洲自拍偷拍在线| 亚洲影院污污.| 国产精品免费视频xxxx| 97视频在线观看播放| 91精品国产网站| 久久av在线播放| 欧美中文在线观看| 热99精品里视频精品| 日韩国产在线看| 狠狠躁天天躁日日躁欧美| 国产一区二区在线免费视频| 欧美视频免费在线| 国产精品三级久久久久久电影| 久久精品亚洲热| 韩国美女主播一区| 成人免费网站在线观看| 亚洲а∨天堂久久精品9966| 亚洲国产另类 国产精品国产免费| 久久免费视频这里只有精品| 欧美激情精品久久久久久| 亚洲男人的天堂在线播放| 在线电影欧美日韩一区二区私密| 91精品国产91久久| 久久av在线播放| 日韩成人在线视频网站| 成人午夜在线视频一区| 亚洲成人三级在线| 亚洲男人天堂网| 成人亚洲综合色就1024| 欧美黄网免费在线观看| 欧美精品第一页在线播放| 深夜福利日韩在线看| 色婷婷综合久久久久| 热久久99这里有精品| 亚洲欧美中文日韩v在线观看| 亚洲香蕉成人av网站在线观看| 在线观看国产欧美| 亚洲视频axxx| 色噜噜狠狠狠综合曰曰曰| 91产国在线观看动作片喷水| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲精品久久在线| 成人免费视频a| 91久久夜色精品国产网站| 日韩av综合网| 亚洲色图五月天| 日日摸夜夜添一区| 亚洲999一在线观看www| 国产精品久久久久久久久免费| 欧美午夜视频在线观看| 欧美性猛交丰臀xxxxx网站| 97国产精品视频人人做人人爱| zzjj国产精品一区二区| 久久久久久999| 欧美影院在线播放| 国产精品免费小视频| 国产精品久久久久一区二区| 欧美激情三级免费| 欧美一区第一页| 日本精品视频在线观看| 91av在线不卡| 欧美在线视频免费播放| 91精品久久久久久综合乱菊| 欧美老女人www| 亚洲免费电影在线观看| 久久亚洲精品小早川怜子66| 成人欧美一区二区三区在线湿哒哒| 国产欧美日韩中文字幕| 久久99热精品这里久久精品| 国产精品人成电影在线观看| 久久伊人精品天天| 日韩中文字幕在线视频| 久久精品一本久久99精品| 亚洲精品久久久久中文字幕欢迎你| 亚洲视频视频在线| 国产精品99久久99久久久二8| 亚洲一区二区在线| 日韩中文在线中文网三级| 欧美色播在线播放| 日韩免费在线免费观看| 美日韩精品免费观看视频| 欧美激情第99页| 国产精品丝袜视频| 精品久久中文字幕久久av| 日韩av123| 久久九九免费视频| 日韩电影中文字幕在线观看| 国产区精品视频| 福利二区91精品bt7086| 日日骚久久av| 国产精品扒开腿做爽爽爽视频| 欧美成年人视频| 日韩av手机在线观看| 亚洲国产欧美一区二区丝袜黑人| 亚洲精品乱码久久久久久按摩观| www.日韩不卡电影av| 热99精品里视频精品| 97av在线影院| 狠狠久久五月精品中文字幕| 中文字幕欧美精品在线| 午夜精品在线观看| 国产日韩欧美在线视频观看| 久久国产视频网站| 高清一区二区三区四区五区| 青青久久av北条麻妃黑人| 日韩中文理论片| 97碰碰碰免费色视频| 亚洲免费一在线| 亚洲人成自拍网站| 亚洲人成网站在线播| 国产精品直播网红| 日韩亚洲成人av在线| 亚洲曰本av电影| 久久精品国产99国产精品澳门| 88国产精品欧美一区二区三区| 欧美国产视频一区二区| 精品亚洲永久免费精品| 亚洲成人黄色网址| 日韩欧美国产成人| 欧美人与物videos| 亚洲欧美国产日韩中文字幕| 亚洲视频在线免费看| 色诱女教师一区二区三区| 欧洲s码亚洲m码精品一区| 久久久午夜视频| 久久的精品视频| 91免费视频国产| 欧美大成色www永久网站婷| 亚洲永久在线观看| 日韩国产中文字幕| 欧美福利视频在线|