mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-03 17:30:00 +00:00
Merge pull request #124444 from claudiubelu/windows/fix-container-log-rotation
windows: Fixes following container log rotation
This commit is contained in:
commit
159d4b837a
@ -295,7 +295,7 @@ func ReadLogs(ctx context.Context, logger *klog.Logger, path, containerID string
|
|||||||
return fmt.Errorf("failed to try resolving symlinks in path %q: %v", path, err)
|
return fmt.Errorf("failed to try resolving symlinks in path %q: %v", path, err)
|
||||||
}
|
}
|
||||||
path = evaluated
|
path = evaluated
|
||||||
f, err := os.Open(path)
|
f, err := openFileShareDelete(path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to open log file %q: %v", path, err)
|
return fmt.Errorf("failed to open log file %q: %v", path, err)
|
||||||
}
|
}
|
||||||
@ -364,7 +364,7 @@ func ReadLogs(ctx context.Context, logger *klog.Logger, path, containerID string
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if recreated {
|
if recreated {
|
||||||
newF, err := os.Open(path)
|
newF, err := openFileShareDelete(path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
continue
|
continue
|
||||||
|
29
staging/src/k8s.io/cri-client/pkg/logs/logs_other.go
Normal file
29
staging/src/k8s.io/cri-client/pkg/logs/logs_other.go
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
//go:build !windows
|
||||||
|
// +build !windows
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2024 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package logs
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
func openFileShareDelete(path string) (*os.File, error) {
|
||||||
|
// Noop. Only relevant for Windows.
|
||||||
|
return os.Open(path)
|
||||||
|
}
|
@ -24,7 +24,6 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
goruntime "runtime"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -212,10 +211,6 @@ func TestReadLogs(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestReadRotatedLog(t *testing.T) {
|
func TestReadRotatedLog(t *testing.T) {
|
||||||
if goruntime.GOOS == "windows" {
|
|
||||||
// TODO: remove skip once the failing test has been fixed.
|
|
||||||
t.Skip("Skip failing test on Windows.")
|
|
||||||
}
|
|
||||||
tmpDir := t.TempDir()
|
tmpDir := t.TempDir()
|
||||||
file, err := os.CreateTemp(tmpDir, "logfile")
|
file, err := os.CreateTemp(tmpDir, "logfile")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -288,6 +283,10 @@ func TestReadRotatedLog(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Finished writing into the file, close it, so we can delete it later.
|
||||||
|
err = file.Close()
|
||||||
|
assert.NoErrorf(t, err, "could not close file.")
|
||||||
|
|
||||||
time.Sleep(20 * time.Millisecond)
|
time.Sleep(20 * time.Millisecond)
|
||||||
// Make the function ReadLogs end.
|
// Make the function ReadLogs end.
|
||||||
fakeRuntimeService.Lock()
|
fakeRuntimeService.Lock()
|
||||||
|
49
staging/src/k8s.io/cri-client/pkg/logs/logs_windows.go
Normal file
49
staging/src/k8s.io/cri-client/pkg/logs/logs_windows.go
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
//go:build windows
|
||||||
|
// +build windows
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2024 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package logs
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"syscall"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Based on Windows implementation of Windows' syscall.Open
|
||||||
|
// https://cs.opensource.google/go/go/+/refs/tags/go1.22.2:src/syscall/syscall_windows.go;l=342
|
||||||
|
// In addition to syscall.Open, this function also adds the syscall.FILE_SHARE_DELETE flag to sharemode,
|
||||||
|
// which will allow us to read from the file without blocking the file from being deleted or renamed.
|
||||||
|
// This is essential for Log Rotation which is done by renaming the open file. Without this, the file rename would fail.
|
||||||
|
func openFileShareDelete(path string) (*os.File, error) {
|
||||||
|
pathp, err := syscall.UTF16PtrFromString(path)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var access uint32 = syscall.GENERIC_READ
|
||||||
|
var sharemode uint32 = syscall.FILE_SHARE_READ | syscall.FILE_SHARE_WRITE | syscall.FILE_SHARE_DELETE
|
||||||
|
var createmode uint32 = syscall.OPEN_EXISTING
|
||||||
|
var attrs uint32 = syscall.FILE_ATTRIBUTE_NORMAL
|
||||||
|
|
||||||
|
handle, err := syscall.CreateFile(pathp, access, sharemode, nil, createmode, attrs, 0)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return os.NewFile(uintptr(handle), path), nil
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user