Skip to content

Commit

Permalink
support k3s runtime api & support specify cri address
Browse files Browse the repository at this point in the history
Signed-off-by: bingshen.wbs <[email protected]>
  • Loading branch information
BSWANG committed Jul 17, 2023
1 parent 6a6adc1 commit b681b8d
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 21 deletions.
2 changes: 2 additions & 0 deletions pkg/skoop/collector/manager/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,15 @@ func init() {
type SimplePodCollectorConfig struct {
Image string
CollectorNamespace string
RuntimeAPIAddress string
WaitInterval time.Duration
WaitTimeout time.Duration
}

func (cc *SimplePodCollectorConfig) BindFlags(fs *pflag.FlagSet) {
fs.StringVarP(&cc.Image, "collector-image", "", "kubeskoop/kubeskoop:v0.1.0", "Image used for collector.")
fs.StringVarP(&cc.CollectorNamespace, "collector-namespace", "", "skoop", "Namespace where collector pods in.")
fs.StringVarP(&cc.CollectorNamespace, "collector-cri-address", "", "", "Runtime CRI API endpoint address.")
fs.DurationVarP(&cc.WaitInterval, "collector-pod-wait-interval", "", 2*time.Second, "Collector pod running check interval.")
fs.DurationVarP(&cc.WaitTimeout, "collector-pod-wait-timeout", "", 120*time.Second, "Collector pod running check timeout.")
}
Expand Down
46 changes: 26 additions & 20 deletions pkg/skoop/collector/manager/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,16 +44,17 @@ type SimplePodCollectorManagerOptions struct {
}

type simplePodCollectorManager struct {
image string
namespace string
client *kubernetes.Clientset
restConfig *rest.Config
ipCache *k8s.IPCache
cache map[string]*k8s.NodeNetworkStackDump
nodeCache map[string]*k8s.NodeInfo
podCache map[string]*k8s.Pod
waitInterval time.Duration
waitTimeout time.Duration
image string
runtimeAPIAddress string
namespace string
client *kubernetes.Clientset
restConfig *rest.Config
ipCache *k8s.IPCache
cache map[string]*k8s.NodeNetworkStackDump
nodeCache map[string]*k8s.NodeInfo
podCache map[string]*k8s.Pod
waitInterval time.Duration
waitTimeout time.Duration
}

func NewSimplePodCollectorManager(ctx *ctx.Context) (collector.Manager, error) {
Expand All @@ -74,16 +75,17 @@ func NewSimplePodCollectorManager(ctx *ctx.Context) (collector.Manager, error) {
}

return &simplePodCollectorManager{
image: Config.SimplePodCollectorConfig.Image,
namespace: Config.SimplePodCollectorConfig.CollectorNamespace,
client: ctx.KubernetesClient(),
restConfig: ctx.KubernetesRestClient(),
ipCache: ctx.ClusterConfig().IPCache,
cache: map[string]*k8s.NodeNetworkStackDump{},
nodeCache: map[string]*k8s.NodeInfo{},
podCache: map[string]*k8s.Pod{},
waitInterval: Config.SimplePodCollectorConfig.WaitInterval,
waitTimeout: Config.SimplePodCollectorConfig.WaitTimeout,
image: Config.SimplePodCollectorConfig.Image,
namespace: Config.SimplePodCollectorConfig.CollectorNamespace,
client: ctx.KubernetesClient(),
restConfig: ctx.KubernetesRestClient(),
ipCache: ctx.ClusterConfig().IPCache,
cache: map[string]*k8s.NodeNetworkStackDump{},
nodeCache: map[string]*k8s.NodeInfo{},
podCache: map[string]*k8s.Pod{},
waitInterval: Config.SimplePodCollectorConfig.WaitInterval,
waitTimeout: Config.SimplePodCollectorConfig.WaitTimeout,
runtimeAPIAddress: Config.SimplePodCollectorConfig.RuntimeAPIAddress,
}, nil
}

Expand Down Expand Up @@ -328,6 +330,10 @@ func (m *simplePodCollectorManager) createCollectorPod(nodeName string) (*v1.Pod
SecurityContext: &v1.SecurityContext{
Privileged: pointer.Bool(true),
},
Env: []v1.EnvVar{{
Name: "RUNTIME_SOCK",
Value: m.runtimeAPIAddress,
}},
Command: []string{"/bin/pod-collector"},
VolumeMounts: []v1.VolumeMount{
{
Expand Down
15 changes: 14 additions & 1 deletion pkg/skoop/collector/podcollector/collector.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,20 @@ func NewCollector(podNamespace, podName, runtimeEndpoint string) (collector.Coll
_, err := os.Stat("/var/run/dockershim.sock")
if err != nil {
if os.IsNotExist(err) {
socket = "unix:///run/containerd/containerd.sock"
containerdSockets := []string{
"unix:///run/containerd/containerd.sock",
"unix:///run/k3s/containerd/containerd.sock",
}

for _, containerdAddr := range containerdSockets {
if _, err = os.Stat(strings.TrimPrefix(containerdAddr, "unix://")); err == nil {
socket = containerdAddr
break
}
}
if socket == "" {
return nil, fmt.Errorf("cannot found comportable endpoint address for cri-api, please specify cri address by --collector-cri-address")
}
} else {
return nil, err
}
Expand Down

0 comments on commit b681b8d

Please sign in to comment.