찾다
php教程php手册PHP滚动日志的代码实现

PHP滚动日志的代码实现

Jun 13, 2016 am 09:02 AM
php암호성취하다통나무가지다스크롤~의클래스 라이브러리기록

PHP滚动日志的代码实现

 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

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

final class LOGS {

private $level;

private $maxFileNum;

private $maxFileSize;

private $logPath;

private $file;

 

//日志的级别DEBUG,MSG,ERR

const LOGS_DEBUG = 0;

const LOGS_MSG = 1;

const LOGS_ERR = 2;

 

private static $instance = null;

 

private function __construct(){}

 

public static function getInstance()

{

if(self::$instance == null)

{

self::$instance = new self();

}

return self::$instance;

}

 

/**

* @Desc 初始化

* @Param $level int 记录级别

* @Param $maxNum int 最大日志文件数目

* @Param $maxSize int 最大日志文件大小

* @Param $logPath string 日志文件保存路径

* @Param $file string 日志文件名称前缀

* @Return boolean

*/

public function init($level, $maxNum, $maxSize, $logPath, $file)

{

$level = intval($level);

$maxNum = intval($maxNum);

$maxSize = intval($maxSize);

!is_dir($logPath) && mkdir($logPath, 0777, true);

if(!in_array($level, array(self::LOGS_DEBUG, self::LOGS_MSG, self::LOGS_ERR)) || $maxNum

{

return false;

}

$this->level = $level;

$this->maxFileNum = $maxNum;

$this->maxFileSize = $maxSize;

$this->logPath = $logPath;

$this->file = $file;

return true;

}

 

/**

* @Desc 获取格式化时间串

*/

public function formatTime()

{

$ustime = explode ( " ", microtime () );

return "[" . date('Y-m-d H:i:s', time()) .".". ($ustime[0] * 1000) . "]";

}

 

/**

* @Desc 滚动方式记录日志文件

*/

public function log($str)

{

$path = $this->logPath.DIRECTORY_SEPARATOR.$this->file.".log";

clearstatcache();

if(file_exists($path))

{

if(filesize($path) >= $this->maxFileSize)

{

$index = 1;

//获取最大的滚动日志数目

for(;$index maxFileNum; $index++)

{

if(!file_exists($this->logPath.DIRECTORY_SEPARATOR.$this->file."_".$index.".log"))

{

break;

}

}

//已经存在maxFileNum个日志文件了

if($index == $this->maxFileNum)

{

$index--;

}

//滚动日志

for(;$index > 1; $index--)

{

$new = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_".$index.".log";

$old = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_".($index - 1).".log";

rename($old, $new);

}

 

$newFile = $this->logPath.DIRECTORY_SEPARATOR.$this->file."_1.log";

rename($path, $newFile);

}

}

$fp = fopen($path, "a+b");

fwrite($fp, $str, strlen($str));

fclose($fp);

return true;

}

 

/**

* @Desc 记录调试信息

* @Param string 日志信息

* @Param string 日志所在文件

* @Param string 日志所在行

*/

public function debug($msg, $file, $line)

{

if($this->level

{

$this->log($this->formatTime()."[{$file}:{$line}]DEBUG: ${msg}\n");

}

}

 

/**

* @Desc 记录信息

* @Param string 日志信息

* @Param string 日志所在文件

* @Param string 日志所在行

*/

public function msg($msg, $file, $line)

{

if($this->level

{

$this->log($this->formatTime()."[{$file}:{$line}]MSG: ${msg}\n");

}

}

 

/**

* @Desc 记录错误信息

* @Param string 日志信息

* @Param string 日志所在文件

* @Param string 日志所在行

*/

public function err($msg, $file, $line)

{

if($this->level

{

$this->log($this->formatTime()."[{$file}:{$line}]ERR: ${msg}\n");

}

}

}

看个例子

#例子中设置记录级别为msg(此时debug信息是不会纪录的),日志文件个数为5,大小为200个字节(测试方便),文件名称为testlog

1

2

3

4

5

$logs = LOGS::getInstance();

$logs->init(1, 5, 200, "./", 'testlog');

 

$logs->msg("YRT", __FILE__, __LINE__);

$logs->debug("YRT", __FILE__, __LINE__);

当我们不停的运行这个例子的时候,会在代码所在文件夹下生成5个文件就像下面这样:

1

2

3

4

5

testlog_4.log

testlog_3.log

testlog_2.log

testlog_1.log

testlog.log #最新的日志在这个文件中

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.