分享
golang log
allenhaozi · · 1976 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
package log
import (
"log"
"os"
"time"
)
var (
debug_log = "debug.log"
log_format = "2006年01月02日-15"
)
var fileHandle *os.File
var cs chan string
func init() {
file_name := getFileName()
fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
log.SetOutput(fileHandle)
cs = make(chan string, 1024)
go WriteChan(cs)
}
func getFileName() string {
now := time.Now()
date := now.Format(log_format)
file_path := "/your/local/dir/"
filename := file_path + debug_log + "." + date
return filename
}
func WriteDebugLog(content string) {
//check log file
curFileName := getFileName()
if _, err := os.Stat(curFileName); os.IsNotExist(err) {
file_name := getFileName()
fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
log.SetOutput(fileHandle)
}
//WriteSingleLog(content)
cs <- content
}
func WriteChan(cs chan string) {
for {
select {
case con := <-cs:
WriteSingleLog(con)
//beego.Debug(len(cs))
}
}
}
func WriteSingleLog(content string) {
log.Println(content)
}
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1976 次点击
上一篇:golang timer
1 回复 | 直到 2025年05月11日 10:07:38
暂无回复
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
package log
import (
"log"
"os"
"time"
)
var (
debug_log = "debug.log"
log_format = "2006年01月02日-15"
)
var fileHandle *os.File
var cs chan string
func init() {
file_name := getFileName()
fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
log.SetOutput(fileHandle)
cs = make(chan string, 1024)
go WriteChan(cs)
}
func getFileName() string {
now := time.Now()
date := now.Format(log_format)
file_path := "/your/local/dir/"
filename := file_path + debug_log + "." + date
return filename
}
func WriteDebugLog(content string) {
//check log file
curFileName := getFileName()
if _, err := os.Stat(curFileName); os.IsNotExist(err) {
file_name := getFileName()
fileHandle, _ = os.OpenFile(file_name, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0755)
log.SetOutput(fileHandle)
}
//WriteSingleLog(content)
cs <- content
}
func WriteChan(cs chan string) {
for {
select {
case con := <-cs:
WriteSingleLog(con)
//beego.Debug(len(cs))
}
}
}
func WriteSingleLog(content string) {
log.Println(content)
}