zoukankan      html  css  js  c++  java
  • golang写日志函数

    
    package common
    
    import (
    	"bufio"
    	"fmt"
    	"os"
    	"time"
    )
    
    
    /*自定义日志文件*/
    func DebugLog(args ...interface{}) error {
    	var floderLog = "logs"
    	logName := floderLog + "/debug_log." + time.Now().Format("2006-01-02") + ".log"
    	if _, err := os.Stat(floderLog); err != nil {
    		if !os.IsExist(err) {
    			os.MkdirAll(floderLog, os.ModePerm)
    		}
    	}
    
    	logFile, err := os.OpenFile(logName, os.O_APPEND|os.O_RDWR|os.O_CREATE, os.ModePerm)
    	if err != nil {
    		fmt.Print("打开文件失败")
    		return err
    	}
    	defer logFile.Close()
    	tm := time.Now().Format("2006-01-02 15:04:05")
    	logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	logFile.WriteString(logBody)
    	logBody = fmt.Sprintf("%+v
    ", args)
    	logFile.WriteString(logBody)
    	logBody = fmt.Sprintf("
    ")
    	logFile.WriteString(logBody)
    	return nil
    }
    
    //DebugLog2 自定义日志文件
    /*
    * dir 文件夹名字
    * fileName 文件名字
    * args 要写入的数据
     */
    func Log(dir string, fileName string, args ...interface{}) error {
    	var floderLog = "logs"
    	if fileName != "" {
    		floderLog = floderLog + "/" + dir
    	}
    	logName := floderLog + "/" + fileName + time.Now().Format("2006-01-02") + ".log"
    	if _, err := os.Stat(floderLog); err != nil {
    		if !os.IsExist(err) {
    			os.MkdirAll(floderLog, os.ModePerm)
    		}
    	}
    
    	logFile, err := os.OpenFile(logName, os.O_APPEND|os.O_RDWR|os.O_CREATE, os.ModePerm)
    	if err != nil {
    		fmt.Println("打开文件失败 err:", err)
    		return err
    	}
    	defer logFile.Close()
    	tm := time.Now().Format("2006-01-02 15:04:05")
    
    	//方法一:os包
    	// logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	// logFile.WriteString(logBody)
    	// logBody = fmt.Sprintf("%+v
    ", args)
    	// logFile.WriteString(logBody)
    	// logBody = fmt.Sprintf("
    ")
    	// logFile.WriteString(logBody)
    
    	//方法二:bufio包
    	writer := bufio.NewWriter(logFile)
    	logBody := fmt.Sprintf("%s star============================================>
    ", tm)
    	writer.WriteString(logBody) //写入缓存
    	logBody = fmt.Sprintf("%+v
    ", args)
    	writer.WriteString(logBody)
    	logBody = fmt.Sprintf("
    ")
    	writer.WriteString(logBody)
    
    	writer.Flush() //从缓存写入文件
    	return nil
    }
    
    
  • 相关阅读:
    linux下利用elk+redis 搭建日志分析平台教程
    C# 短信发送 邮件发送
    面向对象编程思想-装饰模式
    面向对象编程思想-桥接模式
    面向对象编程思想-适配器模式
    面向对象编程思想-原型模式
    面向对象编程思想-建造者模式
    面向对象编程思想-抽象工厂模式
    面向对象编程思想-工厂方法模式
    面向对象编程思想-简单工厂模式
  • 原文地址:https://www.cnblogs.com/haima/p/14004745.html
Copyright © 2011-2022 走看看