Merge pull request #111549 from claudiubelu/log-compression
Fixes kubelet log compression on Windows
This commit is contained in:
@@ -393,11 +393,15 @@ func (c *containerLogManager) compressLog(log string) error {
|
|||||||
if _, err := io.Copy(w, r); err != nil {
|
if _, err := io.Copy(w, r); err != nil {
|
||||||
return fmt.Errorf("failed to compress %q to %q: %v", log, tmpLog, err)
|
return fmt.Errorf("failed to compress %q to %q: %v", log, tmpLog, err)
|
||||||
}
|
}
|
||||||
|
// The archive needs to be closed before renaming, otherwise an error will occur on Windows.
|
||||||
|
w.Close()
|
||||||
|
f.Close()
|
||||||
compressedLog := log + compressSuffix
|
compressedLog := log + compressSuffix
|
||||||
if err := c.osInterface.Rename(tmpLog, compressedLog); err != nil {
|
if err := c.osInterface.Rename(tmpLog, compressedLog); err != nil {
|
||||||
return fmt.Errorf("failed to rename %q to %q: %v", tmpLog, compressedLog, err)
|
return fmt.Errorf("failed to rename %q to %q: %v", tmpLog, compressedLog, err)
|
||||||
}
|
}
|
||||||
// Remove old log file.
|
// Remove old log file.
|
||||||
|
r.Close()
|
||||||
if err := c.osInterface.Remove(log); err != nil {
|
if err := c.osInterface.Remove(log); err != nil {
|
||||||
return fmt.Errorf("failed to remove log %q after compress: %v", log, err)
|
return fmt.Errorf("failed to remove log %q after compress: %v", log, err)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user