douqin3245 2016-06-25 22:39
浏览 87
已采纳

带有O_CREATE标志的os.OpenFile不会抛出这样的文件或目录

I'm trying to open a log file with os package using os.OpenFile function, which should with proper flag create file if such file does not exists. But it returns non nil error: No such file or directory. BTW I'm using linux and go 1.6. Log file opening happens in init function. Heres my code:

package main

import (
    "encoding/json"
    "fmt"
    "log"
    "net/http"
    "os"

    "github.com/gorilla/mux"
    "github.com/gorilla/sessions"
)

// Structs holds server configuration data from config json.
type serverConfiguration struct {
    port                    string
    logFileName             string
    sessionStorePhrase      string
    resourceFilesPath       string
    resourceFilesPathPrefix string
}

// Server global variables.
var (
    serverConfig serverConfiguration
    logFile      *os.File
    router       *mux.Router
    sessionStore *sessions.CookieStore
)

func init() {
    // temporary variables.
    var (
        configFile                                   *os.File
        serverConfErr, configDecodingErr, logFileErr error
    )

    // Loads json config file.
    configFile, serverConfErr = os.Open("server-conf.json")
    defer configFile.Close()

    if serverConfErr != nil {
        log.Fatal("SERVER-CONFIG-ERROR: ", serverConfErr)
    }

    // Decodes json to serverConfig struct.
    decoder := json.NewDecoder(configFile)
    serverConfig = serverConfiguration{}
    configDecodingErr = decoder.Decode(&serverConfig)

    if configDecodingErr != nil {
        log.Fatal("CONFIGURATION-DECODING-ERROR: ", configDecodingErr)
    }

    // Opens log file in app root directory.
    logFile, logFileErr = os.OpenFile(serverConfig.logFileName, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0666)

    if logFileErr != nil {
        log.Fatal("LOG-FILE-ERROR: ", logFileErr)
    }

    // Creates session store.
    sessionStore = sessions.NewCookieStore([]byte(serverConfig.sessionStorePhrase))
}

// Home page handler.
func homePageHandler(writer http.ResponseWriter, request *http.Request) {
    fmt.Fprint(writer, "asdasdasdasd")
}

func main() {
    defer logFile.Close()
    router = mux.NewRouter().StrictSlash(false)
    resourceFileServer := http.FileServer(http.Dir(serverConfig.resourceFilesPath))
    router.PathPrefix(serverConfig.resourceFilesPathPrefix).Handler(http.StripPrefix(serverConfig.resourceFilesPathPrefix, resourceFileServer))

    router.HandleFunc("/", homePageHandler)

    server := &http.Server{
        Addr:    serverConfig.port,
        Handler: router,
    }

    log.Println("Server listening on port ", serverConfig.port)
    server.ListenAndServe()
}
  • 写回答

2条回答 默认 最新

  • doulang6695 2016-06-25 23:05
    关注

    The error is most likely that the path you want to create your file in doesn't exist. it will create the logfile, but not the parent directories if they don't exist. To create the necessary directory structure, you could use os.MkdirAll

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题