golang判断目录是否存在和生成日志文件

package main

import (

"fmt"

"io"

"os"

"time"

"github.com/sirupsen/logrus"

)

func main() {

defer func() {

err := recover()

if err != nil {

logrus.Info(err)

}

}()

log_path := "runtime/logs/"

_, err := os.Stat(log_path)

if err != nil {

if os.IsNotExist(err) {

err = os.MkdirAll(log_path, 0755)

if err != nil {

logrus.Fatal("目录创建错误", err)

}

}

}

log_file := log_path + "error" + time.Now().Format("2006-01-02") + ".log"

fd, err := os.OpenFile(log_file, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)

if err != nil {

logrus.Info("打开文件错误", err)

return

}

logrus.SetOutput(io.MultiWriter(os.Stdout, fd))

Test(1, 0)

}

func Test(x int, y int) {

a := x / y

fmt.Println(a)

}

相关推荐
何以解忧,唯有..15 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
踏着七彩祥云的小丑15 天前
Go学习第9天:并发编程 + 文件操作 + 正则表达式
学习·golang·正则表达式·go
JCGKS15 天前
Go `init` 函数:包初始化顺序到底是怎样的
golang·init·init执行顺序
何以解忧,唯有..15 天前
Go语言中的const:常量声明与iota枚举详解
java·开发语言·golang
geovindu15 天前
go: Reactor Pattern
开发语言·后端·设计模式·golang·反应器模式
記億揺晃着的那天16 天前
Java 调用外部 Go 程序的实践:ProcessBuilder 在生产环境中的应用
java·golang·processbuilder
jingling55516 天前
go | 环境安装和快速入门
开发语言·后端·golang
java_cj16 天前
从kubectl学Visitor模式:如何优雅处理多态数据结构的遍历
云原生·golang·k8s·访问者模式
何以解忧,唯有..16 天前
Go语言类型转换详解:从基础到进阶实践
开发语言·后端·golang
何以解忧,唯有..16 天前
Go 语言指针类型详解:从基础到实战
开发语言·后端·golang