-
Notifications
You must be signed in to change notification settings - Fork 3.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: for Windows, copy snapshot files being backed up #22551
Conversation
On Windows, make copies of files for snapshots, because Go does not support the FILE_SHARE_DELETE flag which allows files (and links) to be deleted while open. This causes temporary directories to be left behind after backups. closes #16289
This should get backported to 1.8 |
) | ||
|
||
// copyOrLink - allow substitution of a file copy for a hard link when running on Windows systems. | ||
func copyOrLink(oldPath, newPath string) error { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might be more straightforward to just check runtime.GOOS == "windows"
, but this is fine
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That was my original implementation, but reading various Go blogs convinced me conditional compilation was more idiomatic.
if _, err := io.Copy(wfd, rfd); err != nil { | ||
return fmt.Errorf("unable to copy file for backup from %s to %s: %q", oldPath, newPath, err) | ||
} | ||
if err := os.Chtimes(newPath, fi.ModTime(), fi.ModTime()); err != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Kind of ugly that Chtimes takes aTime here but only exposes reading ModTime in a cross-platform way - might be worth a comment
On Windows, make copies of files for snapshots, because Go does not support the FILE_SHARE_DELETE flag which allows files (and links) to be deleted while open. This causes temporary directories to be left behind after backups. closes #16289 (cherry picked from commit 3702fe8) closes #22557 (cherry picked from commit 47007f6)
… (#22563) On Windows, make copies of files for snapshots, because Go does not support the FILE_SHARE_DELETE flag which allows files (and links) to be deleted while open. This causes temporary directories to be left behind after backups. closes #16289 (cherry picked from commit 3702fe8) closes #22557 (cherry picked from commit 47007f6) closes #22558
On Windows, make copies of files for snapshots, because
Go does not support the FILE_SHARE_DELETE flag which
allows files (and links) to be deleted while open. This
causes temporary directories to be left behind after
backups.
closes #16289