EasyGBS如何解决日志过大打不开的问题?巧用日志分割功能

2021-06-18 18:12:01 浏览数 (1)

在EasyGBS接入设备的限度上,理论上是没有最高限度的,但是根据服务器的运行能力,接入设备过多的话会出现的一些卡顿或者故障。在我们遇到的某些项目现场上,用户接入设备数过多,会导致日志消息频繁打印,日志过大,出现无法打开日志的问题。

日志文件夹logs,系统日志文件****-yyyymmdd.log **** -error.log、**** -sms-yyyymmdd.log,需要将其按照大小和时间分割,达到****-yyyymmdd.log.1、****-yyyymmdd.log.2这样的效果。

分割之前,打开缓慢,需要疯狂加载:

随后我们需要实行以上的分割方案,日志打印之前先从配置文件读取出日志文件的单个文件配置大小,在根据当前日志的大小进行判断,是否需要分割。参考代码如下:

代码语言:javascript复制
if rl != nil {
   return rl
}
alarm := Conf().Section("module")
logSize := alarm.Key("log_size").MustInt(0)
logDir := LogDir()
logFile := filepath.Join(logDir, strings.ToLower(EXEName()) "-%Y%m%d.log")
if logSize > 0 {
   _rl, err := rotatelogs.New(logFile, rotatelogs.WithMaxAge(time.Hour*24*3), rotatelogs.WithRotationSize(int64(logSize*1024*1024)))
   if err == nil {
      rl = _rl
      return rl
   }

分割之后减轻了单个日志的压力,日志则能正常打开:

0 人点赞