Skip to content

Commit

Permalink
Fix containerd hosts.toml path on windows
Browse files Browse the repository at this point in the history
Signed-off-by: Brad Davidson <[email protected]>
  • Loading branch information
brandond committed Feb 6, 2025
1 parent 41f0c6a commit 1d6fd10
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pkg/agent/containerd/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ func writeContainerdHosts(cfg *config.Node, containerdConfig templates.Container

// Write out new templates
for host, config := range hosts {
hostDir := filepath.Join(cfg.Containerd.Registry, host)
hostDir := filepath.Join(cfg.Containerd.Registry, hostDirectory(host))
hostsFile := filepath.Join(hostDir, "hosts.toml")
hostsTemplate, err := templates.ParseHostsTemplateFromConfig(templates.HostsTomlTemplate, config)
if err != nil {
Expand Down
6 changes: 6 additions & 0 deletions pkg/agent/containerd/config_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,12 @@ const (
runtimesPath = "/usr/local/nvidia/toolkit:/opt/kwasm/bin"
)

// hostDirectory returns the name of the host dir for a given registry.
// This is a no-op on linux, as all possible host:port strings are valid paths.
func hostDirectory(host string) string {
return host
}

func getContainerdArgs(cfg *config.Node) []string {
args := []string{
"containerd",
Expand Down
2 changes: 1 addition & 1 deletion pkg/agent/containerd/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1500,7 +1500,7 @@ func Test_UnitGetHostConfigs(t *testing.T) {
for host, config := range got {
hostsTemplate, err := templates.ParseHostsTemplateFromConfig(templates.HostsTomlTemplate, config)
assert.NoError(t, err, "ParseHostTemplateFromConfig for %s", host)
t.Logf("%s/hosts.d/%s/hosts.toml\n%s", tempDir, host, hostsTemplate)
t.Logf("%s/hosts.d/%s/hosts.toml\n%s", tempDir, hostDirectory(host), hostsTemplate)
}

// Confirm that the main containerd config.toml renders properly
Expand Down
12 changes: 12 additions & 0 deletions pkg/agent/containerd/config_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
package containerd

import (
"net"

"github.com/containerd/containerd"
"github.com/k3s-io/k3s/pkg/agent/templates"
"github.com/k3s-io/k3s/pkg/daemons/config"
Expand All @@ -13,6 +15,16 @@ import (
"k8s.io/cri-client/pkg/util"
)

// hostDirectory returns the name of the host dir for a given registry.
// Colons are not allowed in windows paths, so convert `:port` to `_port_`.
// Ref: https://github.com/containerd/containerd/blob/v1.7.25/remotes/docker/config/hosts.go#L291-L298
func hostDirectory(host string) string {
if host, port, err := net.SplitHostPort(host); err == nil && port != "" {
return host + "_" + port + "_"
}
return host
}

func getContainerdArgs(cfg *config.Node) []string {
args := []string{
"containerd",
Expand Down

0 comments on commit 1d6fd10

Please sign in to comment.