• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Go语言的日志记录功能

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

Go目前标准包中日志只是方便的实现日志记录的功能,这些日志都是基于fmt包的打印再结合panic之类的函数来进行一般的打印、抛出错误处理。

一个简单的日志记录代码例子:

代码来自:http://www.du52.com/text.php?id=114

package main
 
import(
    "fmt"
    "log"
    "os"
)
 
func main(){
    logfile,err:=os.OpenFile("/Users/cybercare/tmp/test.log",os.O_RDWR|os.O_CREATE,0666)
    if err!=nil{
        fmt.Printf("%s\r\n",err.Error())
        os.Exit(-1)
    }
    defer logfile.Close()
    logger:=log.New(logfile,"\r\n",log.Ldate|log.Ltime|log.Llongfile)
    logger.Println("hello")
    logger.Println("oh....")
    logger.Fatal("test")
    logger.Fatal("test2")
}
在log文件中显示的是:

2013/03/16 17:28:18 /Users/cybercare/go/src/test1/main.go:18: hello

2013/03/16 17:28:18 /Users/cybercare/go/src/test1/main.go:19: oh....

2013/03/16 17:28:18 /Users/cybercare/go/src/test1/main.go:20: test

日志当然也可以不记录在文件中,默认是不记录在文件中的:

下面是一个例子:linux下通过go语言获得系统进程cpu使用情况,这段代码通过linux的系统命令 ps来分析cpu的使用情况

代码出处:http://www.sharejs.com/codes/go/5662

package main
 
import(
    "bytes"
    "log"
    "os/exec"
    "strconv"
    "strings"
)
 
type Process struct{
    pid int
    cpu float64
}
 
func main(){
    cmd:=exec.Command("ps","aux")
    var out bytes.Buffer
    cmd.Stdout=&out
    err:=cmd.Run()
    if err!=nil{
        log.Fatal(err)
    }
    processes:=make([]*Process,0)
    for{
        line,err:=out.ReadString('\n')
        if err!=nil{
            break
        }
        tokens:=strings.Split(line,"")
        ft:=make([]string,0)
        for _,t:=range tokens{
            if t!=""&&t!="\t"{
                ft=append(ft,t)
            }
        }
        log.Println(len(ft),ft)
        pid,err:=strconv.Atoi(ft[1])
        if err!=nil{
            continue
        }
        cpu,err:=strconv.ParseFloat(ft[2],64)
        if err!=nil{
            log.Fatal(err)
        }
        processes=append(processes,&Process{pid,cpu})
    }
    for _,p:=range processes{
        log.Println("Process",p.pid,"takes",p.cpu,"%oftheCPU")
    }
}

 

 

 

读写文件的操作例子可以解决:

golang 读写文件 
http://www.dotcoo.com/golang-file-demo

 

 

            
                

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Go语言内存模型发布时间:2022-07-10
下一篇:
go基础三 数组,切片,map,list发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap