
The path module has a few different functions: Clean, Split, Join, Ext, Dir, Base, IsAbs. These functions do not take into account the OS-specific path separator, meaning that they won't behave as intended on Windows. For example, Dir is supposed to return all but the last element of the path. For the path "C:\some\dir\somewhere", it is supposed to return "C:\some\dir\", however, it returns ".". Instead of these functions, the ones in filepath should be used instead.
76 lines
2.7 KiB
Go
76 lines
2.7 KiB
Go
/*
|
|
Copyright 2016 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 kuberuntime
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
"strings"
|
|
|
|
kubecontainer "k8s.io/kubernetes/pkg/kubelet/container"
|
|
)
|
|
|
|
// This file implements the functions that are needed for backward
|
|
// compatibility. Therefore, it imports various kubernetes packages
|
|
// directly.
|
|
|
|
const (
|
|
// legacyContainerLogsDir is the legacy location of container logs. It is the same with
|
|
// kubelet.containerLogsDir.
|
|
legacyContainerLogsDir = "/var/log/containers"
|
|
// legacyLogSuffix is the legacy log suffix.
|
|
legacyLogSuffix = "log"
|
|
|
|
ext4MaxFileNameLen = 255
|
|
)
|
|
|
|
// legacyLogSymlink composes the legacy container log path. It is only used for legacy cluster
|
|
// logging support.
|
|
func legacyLogSymlink(containerID string, containerName, podName, podNamespace string) string {
|
|
return logSymlink(legacyContainerLogsDir, kubecontainer.BuildPodFullName(podName, podNamespace),
|
|
containerName, containerID)
|
|
}
|
|
|
|
// getContainerIDFromLegacyLogSymlink returns error if container Id cannot be parsed
|
|
func getContainerIDFromLegacyLogSymlink(logSymlink string) (string, error) {
|
|
parts := strings.Split(logSymlink, "-")
|
|
if len(parts) == 0 {
|
|
return "", fmt.Errorf("unable to find separator in %q", logSymlink)
|
|
}
|
|
containerIDWithSuffix := parts[len(parts)-1]
|
|
suffix := fmt.Sprintf(".%s", legacyLogSuffix)
|
|
if !strings.HasSuffix(containerIDWithSuffix, suffix) {
|
|
return "", fmt.Errorf("%q doesn't end with %q", logSymlink, suffix)
|
|
}
|
|
containerIDWithoutSuffix := strings.TrimSuffix(containerIDWithSuffix, suffix)
|
|
// container can be retrieved with container Id as short as 6 characters
|
|
if len(containerIDWithoutSuffix) < 6 {
|
|
return "", fmt.Errorf("container Id %q is too short", containerIDWithoutSuffix)
|
|
}
|
|
return containerIDWithoutSuffix, nil
|
|
}
|
|
|
|
func logSymlink(containerLogsDir, podFullName, containerName, containerID string) string {
|
|
suffix := fmt.Sprintf(".%s", legacyLogSuffix)
|
|
logPath := fmt.Sprintf("%s_%s-%s", podFullName, containerName, containerID)
|
|
// Length of a filename cannot exceed 255 characters in ext4 on Linux.
|
|
if len(logPath) > ext4MaxFileNameLen-len(suffix) {
|
|
logPath = logPath[:ext4MaxFileNameLen-len(suffix)]
|
|
}
|
|
return filepath.Join(containerLogsDir, logPath+suffix)
|
|
}
|