Golang 写日志到文件

Go 复制代码
package main

import (
	"log"
	"os"
	"time"
)

func main() {
	printLog("auto", "报警内容AA")
}

func printLog(filename string, content string) {
	t := time.Now().Format(time.DateOnly)
	file := filename + "." + t + ".log"
    //日志名称为 xx.2024-03-07.log

	f, err := os.OpenFile(file, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
	if err != nil {
		log.Panic("打开日志文件异常")
	}
	defer f.Close() // 延迟关闭文件句柄
	log.SetOutput(f)
	log.Print(content)
}

OpenFile常用的打开模式:

os.O_RDONLY: 以只读方式打开文件

os.O_WRONLY: 以只写方式打开文件

os.O_RDWR: 以读写方式打开文件

os.O_APPEND: 在文件末尾追加数据

os.O_CREATE: 如果文件不存在则创建新文件

os.O_EXCL: 与O_CREATE一起使用时,要求文件必须是新创建的,如果文件已经存在则返回错误

os.O_SYNC: 打开文件用于同步I/O

os.O_TRUNC: 如果可能,打开文件时先将文件内容清空

相关推荐
咖啡啡不加糖1 分钟前
Arthas 使用指南:Java 应用诊断利器
java·spring boot·后端
J_liaty2 分钟前
SpringBoot整合Canal实现数据库实时同步
数据库·spring boot·后端·canal
lead520lyq2 分钟前
Golang Grpc接口调用实现账号密码认证
开发语言·后端·golang
EQ-雪梨蛋花汤2 分钟前
【问题反馈】JNI 开发:为什么 C++ 在 Debug 正常,Release 却返回 NaN?
开发语言·c++
naruto_lnq3 分钟前
高性能消息队列实现
开发语言·c++·算法
charlie1145141913 分钟前
malloc 在多线程下为什么慢?——从原理到实测
开发语言·c++·笔记·学习·工程实践
JaguarJack5 分钟前
Laravel AI SDK 在 Laracon India 2026 首次亮相
后端·php·laravel
kyrie学java6 分钟前
SpringWeb
java·开发语言
写代码的【黑咖啡】8 分钟前
Python 中的 Gensim 库详解
开发语言·python
小二·9 分钟前
Go 语言系统编程与云原生开发实战(第6篇)云原生部署实战:Docker 镜像瘦身 × K8s 部署 × Helm 一键发布
docker·云原生·golang