Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

异步输出日志

对于日志输出即时行要求不高的内容,可以通过异步的方式输出日志,异步输出使得日志打印调用可立即返回,因此效率较高。glog当然支持异步输出特性,并且内部使用了goroutine池来管理异步日志打印任务,可以充分的降低对资源的占用率。

...

如果对于同一个文件日志输出既采用了同步打印,也采用了异步打印,注意日志文件的内容可能会出现乱序问题,这种情况应当尽量避免。

使用示例1,SetAsync

我们来看一个使用SetAsync方法实现异步打印的示例。

...

2019-06-02 15:44:21.399 async log 0
2019-06-02 15:44:21.399 async log 1
2019-06-02 15:44:21.399 async log 2
2019-06-02 15:44:21.399 async log 3
2019-06-02 15:44:21.399 async log 4
2019-06-02 15:44:21.399 async log 5
2019-06-02 15:44:21.399 async log 6
2019-06-02 15:44:21.399 async log 7
2019-06-02 15:44:21.399 async log 8
2019-06-02 15:44:21.399 async log 9

使用示例2,Async链式操作

使用链式操作比较简单。

package main

import (
	"github.com/gogf/gf/os/glog"
	"time"
)

func main() {
	for i := 0; i < 10; i++ {
		glog.Async().Print("async log", i)
	}
	time.Sleep(time.Second)
}

...