mirror of https://github.com/kubernetes/kops.git
Install crictl on node
This commit is contained in:
parent
d6e74ef9a1
commit
2beee63f3e
|
@ -0,0 +1,48 @@
|
|||
package model
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"k8s.io/kops/upup/pkg/fi"
|
||||
"k8s.io/kops/upup/pkg/fi/nodeup/nodetasks"
|
||||
"k8s.io/kops/util/pkg/distributions"
|
||||
)
|
||||
|
||||
type CrictlBuilder struct {
|
||||
*NodeupModelContext
|
||||
}
|
||||
|
||||
var _ fi.NodeupModelBuilder = &CrictlBuilder{}
|
||||
|
||||
func (b *CrictlBuilder) Build(c *fi.NodeupModelBuilderContext) error {
|
||||
assetName := "crictl"
|
||||
assetPath := ""
|
||||
asset, err := b.Assets.Find(assetName, assetPath)
|
||||
if err != nil {
|
||||
return fmt.Errorf("unable to locate asset %q", err)
|
||||
}
|
||||
|
||||
c.AddTask(&nodetasks.File{
|
||||
Path: b.crictlPath(),
|
||||
Contents: asset,
|
||||
Type: nodetasks.FileType_File,
|
||||
Mode: s("0755"),
|
||||
})
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b *CrictlBuilder) binaryPath() string {
|
||||
path := "/usr/local/bin"
|
||||
if b.Distribution == distributions.DistributionFlatcar {
|
||||
path = "/opt/kops/bin"
|
||||
}
|
||||
if b.Distribution == distributions.DistributionContainerOS {
|
||||
path = "/home/kubernetes/bin"
|
||||
}
|
||||
return path
|
||||
}
|
||||
|
||||
func (b *CrictlBuilder) crictlPath() string {
|
||||
return b.binaryPath() + "/crictl"
|
||||
}
|
|
@ -1154,6 +1154,14 @@ func (c *ApplyClusterCmd) addFileAssets(assetBuilder *assets.AssetBuilder) error
|
|||
}
|
||||
}
|
||||
|
||||
crictlAssetUrl, crictlAssetHash, err := findCrictlAsset(c.Cluster, assetBuilder, arch)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if crictlAssetUrl != nil && crictlAssetHash != nil {
|
||||
c.Assets[arch] = append(c.Assets[arch], mirrors.BuildMirroredAsset(crictlAssetUrl, crictlAssetHash))
|
||||
}
|
||||
|
||||
asset, err := NodeUpAsset(assetBuilder, arch)
|
||||
if err != nil {
|
||||
return err
|
||||
|
|
|
@ -0,0 +1,40 @@
|
|||
package cloudup
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/url"
|
||||
|
||||
"k8s.io/kops/pkg/apis/kops"
|
||||
"k8s.io/kops/pkg/assets"
|
||||
"k8s.io/kops/util/pkg/architectures"
|
||||
"k8s.io/kops/util/pkg/hashing"
|
||||
)
|
||||
|
||||
const (
|
||||
crictlAssetUrlAmd64 = "https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.29.0/crictl-v1.29.0-linux-amd64.tar.gz"
|
||||
crictlAssetUrlArm64 = "https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.29.0/crictl-v1.29.0-linux-arm64.tar.gz"
|
||||
)
|
||||
|
||||
func findCrictlAsset(c *kops.Cluster, assetBuilder *assets.AssetBuilder, arch architectures.Architecture) (*url.URL, *hashing.Hash, error) {
|
||||
var assetURL string
|
||||
switch arch {
|
||||
case architectures.ArchitectureAmd64:
|
||||
assetURL = crictlAssetUrlAmd64
|
||||
case architectures.ArchitectureArm64:
|
||||
assetURL = crictlAssetUrlArm64
|
||||
default:
|
||||
return nil, nil, fmt.Errorf("unknown arch for crictl binaries asset: %s", arch)
|
||||
}
|
||||
|
||||
u, err := url.Parse(assetURL)
|
||||
if err != nil {
|
||||
return nil, nil, fmt.Errorf("unable to parse crictl binaries asset URL %q: %v", assetURL, err)
|
||||
}
|
||||
|
||||
u, h, err := assetBuilder.RemapFileAndSHA(u)
|
||||
if err != nil {
|
||||
return nil, nil, fmt.Errorf("unable to remap crictl binaries asset: %v", err)
|
||||
}
|
||||
|
||||
return u, h, err
|
||||
}
|
|
@ -315,6 +315,7 @@ func (c *NodeUpCommand) Run(out io.Writer) error {
|
|||
loader.Builders = append(loader.Builders, &model.WarmPoolBuilder{NodeupModelContext: modelContext})
|
||||
loader.Builders = append(loader.Builders, &model.PrefixBuilder{NodeupModelContext: modelContext})
|
||||
loader.Builders = append(loader.Builders, &model.NerdctlBuilder{NodeupModelContext: modelContext})
|
||||
loader.Builders = append(loader.Builders, &model.CrictlBuilder{NodeupModelContext: modelContext})
|
||||
|
||||
loader.Builders = append(loader.Builders, &networking.CommonBuilder{NodeupModelContext: modelContext})
|
||||
loader.Builders = append(loader.Builders, &networking.CalicoBuilder{NodeupModelContext: modelContext})
|
||||
|
|
Loading…
Reference in New Issue