douqin3245 2016-06-25 14: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 15: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条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部