Go语言的日志记录功能
2013-03-17 22:01
197 查看
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: hello2013/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
相关文章推荐
- go语言使用官方的 log package 来记录日志
- Go语言 常用日志记录方法
- Go语言程序记录日志
- go语言学习------Go 记录日志——log包
- go语言日志记录库简单使用方法实例分析
- java动态代理详解,并用动态代理和注解实现日志记录功能
- Secure CRT 自动记录日志和时间戳功能配置
- 【脚本语言系列】关于 JavaScript 日志功能,你需要知道的事
- SecureCRT7.0使用之自动记录日志功能
- 05年写的记录日志功能, 很简单, 但很实用
- 使用Aop面向切面技术实现记录详细操作日志功能
- PHP学习:日志记录功能
- HAproxy增加日志记录功能和自定义日志输出内容、格式
- spring aop 面向切面编程 如何来做一个强大的日志记录功能
- .Net语言 APP开发平台——Smobiler学习日志:如何快速实现手机上的资源上传功能
- Go语言的网络功能太强了,这么多项目。。。
- php之框架增加日志记录功能类
- go语言学习-未分类的一些记录
- Spring 自定义注解实现操作日志记录功能