对于日志输出即时性要求不高的内容,可以通过异步的方式输出日志,异步输出使得日志打印调用可立即返回,因此效率较高。glog
当然支持异步输出特性,并且内部使用了GOroutine
池来管理异步日志打印任务,可以充分的降低对资源的占用率。
创新互联公司主营义安网站建设的网络公司,主营网站建设方案,手机APP定制开发,义安h5微信小程序开发搭建,义安网站营销推广欢迎义安等地区企业咨询
异步输出可以通过日志对象的SetAsync
/SetFlags
方法,或者通过链式操作Async
方法实现。但是需要注意的是,如果通过对象设置方法设置异步输出,那么后续所有的日志输出都将是异步的;如果是通过链式操作输出,那么仅对当前日志输出为异步。
如果对于同一个文件日志输出既采用了同步打印,也采用了异步打印,注意日志文件的内容可能会出现乱序问题,这种情况应当尽量避免。
我们来看一个使用SetAsync
方法实现异步打印的示例。
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
g.Log().SetAsync(true)
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
}
执行后,可以发现终端什么内容也没有输出,因为日志输出的异步的,该示例在日志内容还没有输出之前就退出了。因此,我们可以稍做改进如下:
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
g.Log().SetAsync(true)
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
time.Sleep(time.Second)
}
执行后,终端输出结果为:
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
使用链式操作比较简单。
package main
import (
"context"
"time"
"github.com/gogf/gf/v2/frame/g"
)
func main() {
ctx := context.TODO()
for i := 0; i < 10; i++ {
g.Log().Print(ctx, "async log", i)
}
g.Log().Print(ctx, "normal log")
g.Log().Print(ctx, "normal log")
g.Log().Print(ctx, "normal log")
time.Sleep(time.Second)
}
执行后,终端输出结果为:
2022-01-05 15:00:44.101 normal log
2022-01-05 15:00:44.101 async log 0
2022-01-05 15:00:44.101 async log 1
2022-01-05 15:00:44.101 async log 2
2022-01-05 15:00:44.101 async log 3
2022-01-05 15:00:44.101 async log 4
2022-01-05 15:00:44.101 async log 5
2022-01-05 15:00:44.101 async log 6
2022-01-05 15:00:44.101 async log 7
2022-01-05 15:00:44.101 async log 8
2022-01-05 15:00:44.101 async log 9
2022-01-05 15:00:44.101 normal log
2022-01-05 15:00:44.103 normal log
名称栏目:创新互联GoFrame教程:GoFrame日志组件-异步输出
分享路径:http://www.gawzjz.com/qtweb2/news36/13686.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联