Golang之beego读取配置信息,输出log模块

1,准备好配置文件

[server]
listen_ip = "0.0.0.0"
listen_port = 8888

[logs]
log_level=debug
log_path=./logs/logagent.log

[collect]
log_path=D:\project\logs\logagent.log
topic=nginx_log
chan_size=100

通过golang读取配置文件

package main

import (
    "fmt"
    "github.com/astaxie/beego/config"
)

func main() {
    conf, err := config.NewConfig("ini", "D:/project/src/go_dev/day11/config/logagent.conf")
    if err != nil {
        fmt.Println("new config failed, err:", err)
        return
    }

    port ,err:= conf.Int("server::listen_port")
    if err != nil {
        fmt.Println("read server:port failed, err:", err)
        return
    }

    fmt.Println("port:", port)

    log_level := conf.String("logs::log_level")
    if len(log_level) == 0 {
        log_level = "debug"
    }

    fmt.Println("log_level:", log_level)

    log_path := conf.String("collect::log_path")
    fmt.Println("log_path:", log_path)
}

main.go运行结果

port: 8888
log_level: debug
log_path: D:\project\logs\logagent.log

Process finished with exit code 0

2,beego输出log文件日志

main.go

package main

import (
    "encoding/json"
    "fmt"
    "github.com/astaxie/beego/logs"
)

func main() {
    config := make(map[string]interface{})
    config["filename"] = "D:/project/src/go_dev/day11/logs/logcollect.log"
    config["level"] = logs.LevelDebug

    configStr, err := json.Marshal(config)
    if err != nil {
        fmt.Println("marshal failed,err:", err)
        return
    }
    logs.SetLogger(logs.AdapterFile, string(configStr))
    logs.Debug("this is a test,my name is %s", "stu01")
    logs.Trace("this is a trace,my name is %s", "stu02")
    logs.Warn("this is a warn,my name is %s", "stu03")
}

运行结果,生成log文件

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏web前端

smartClient 2--可视化组件

三、资源:https://www.smartclient.com/smartclient/showcase/?id=formLayoutFilling&skin...

1260
来自专栏韦弦的偶尔分享

微信小程序导航参数中含有问号

和三一样,还可以使用 encodeURIComponent 和 decodeURIComponent 这就是小程序中导航的参数含有?的解决方案,如果还有其他好...

5802
来自专栏web前端

smartClient 2--可视化组件

一、功能:     1、标准功能 Foundation Services Foundation Components Event Handling Contr...

2269
来自专栏CDA数据分析师

50个逆天功能,看完变Excel绝顶高手(全都是动图!)

Excel的50个逆天功能,动画教程珍藏版。 1、自动筛选 ? 2、在Excel中字符替换 ? 3、在Excel中冻结行列标题 ? 4、在Excel中为导入外部...

2846
来自专栏用户2442861的专栏

sublime text 配置php调试环境(快捷键)

2、在sublime text 2中 工具->编译系统->新建编译系统 添加如下代码:

2071
来自专栏pangguoming

Excel 2013中单元格添加下拉列表的方法

使用Excel录入数据的时候我们通常使用下拉列表来限定输入的数据,这样录入数据就很少发生错误了。Excel 2013较以前的版本发生了很大的变化,那么在Exce...

3308
来自专栏Golang语言社区

go channel 通信通道

go中最重要的一种通信通道就是channel 1.给一个 nil channel 发送数据,造成永远阻塞 2.从一个 nil channel 接收数据,造成...

3113
来自专栏禅林阆苑

Sublime快捷键与常用插件配置总结 【原创】

Sublime快捷键与常用插件配置总结 Write By CS逍遥剑仙 我的主页: www.csxiaoyao.com GitHub: git...

4238
来自专栏Ryan Miao

sublime Text3使用笔记

转载:http://blog.csdn.net/u012771929/article/details/30030249 目录: 1.setting   安装插件...

36411
来自专栏更流畅、简洁的软件开发方式

页面回发后,让页面自动滚动到指定位置的一种简单的方法

最近某客户做实施,顺便完善一下程序。突然找到了一个老问题的解决方法。 就是当用户按一个按钮后,希望回发后的页面滚到一个指定的位置,而不是页面的开头部分。以...

3597

扫码关注云+社区

领取腾讯云代金券