stoarge: fix 'access denied' error on Windows

On Windows, it is not possible to rename or delete a file that is
currerntly open. This change closes the file in dropAndPersistChunks
before it tries to delete it, or rename the temporary file to it.
This commit is contained in:
Jan van Valburg 2016-06-16 22:00:44 +01:00 committed by Fabian Reinartz
parent beecbe3d2f
commit 68f3df49d0
1 changed files with 6 additions and 0 deletions

View File

@ -812,6 +812,9 @@ func (p *persistence) dropAndPersistChunks(
}
_, err = io.ReadFull(f, headerBuf)
if err == io.EOF {
// Close the file before trying to delete it. This is necessary on Windows
// (this will cause the defer f.Close to fail, but the error is silently ignored)
f.Close()
// We ran into the end of the file without finding any chunks that should
// be kept. Remove the whole file.
if numDropped, err = p.deleteSeriesFile(fp); err != nil {
@ -875,6 +878,9 @@ func (p *persistence) dropAndPersistChunks(
return
}
defer func() {
// Close the file before trying to rename to it. This is necessary on Windows
// (this will cause the defer f.Close to fail, but the error is silently ignored)
f.Close()
p.closeChunkFile(temp)
if err == nil {
err = os.Rename(p.tempFileNameForFingerprint(fp), p.fileNameForFingerprint(fp))