/
provider.go
141 lines (117 loc) · 3.61 KB
/
provider.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
package cluster
import (
"path"
"strings"
devopsv1 "github.com/wtxue/kok-operator/pkg/apis/devops/v1"
"github.com/wtxue/kok-operator/pkg/constants"
"github.com/wtxue/kok-operator/pkg/controllers/common"
"github.com/wtxue/kok-operator/pkg/provider/baremetal/validation"
clusterprovider "github.com/wtxue/kok-operator/pkg/provider/cluster"
"github.com/wtxue/kok-operator/pkg/provider/config"
"github.com/wtxue/kok-operator/pkg/util/pointer"
"k8s.io/apimachinery/pkg/util/validation/field"
"k8s.io/apiserver/pkg/server/mux"
)
func Add(mgr *clusterprovider.CpManager, cfg *config.Config) error {
p, err := NewProvider(mgr, cfg)
if err != nil {
return err
}
mgr.Register(p.Name(), p)
return nil
}
type Provider struct {
*clusterprovider.DelegateProvider
Mgr *clusterprovider.CpManager
Cfg *config.Config
}
var _ clusterprovider.Provider = &Provider{}
func NewProvider(mgr *clusterprovider.CpManager, cfg *config.Config) (*Provider, error) {
p := &Provider{
Mgr: mgr,
Cfg: cfg,
}
p.DelegateProvider = &clusterprovider.DelegateProvider{
ProviderName: "baremetal",
CreateHandlers: []clusterprovider.Handler{
p.EnsureCopyFiles,
p.EnsurePreInstallHook,
p.EnsureRegistryHosts,
p.EnsureNvidiaDriver,
p.EnsureNvidiaContainerRuntime,
p.EnsureSystem,
p.EnsureEth,
p.EnsureCRI,
p.EnsureK8sComponent,
p.EnsurePreflight,
p.EnsureClusterComplete,
p.EnsureImagesPull,
p.EnsureCerts,
p.EnsureKubeadmInitKubeletStartPhase, // start kubelet
p.EnsureBuildLocalKubeconfig,
p.EnsureKubeMiscPhase,
p.EnsureKubeadmInitControlPlanePhase,
p.EnsureKubeadmInitEtcdPhase,
p.EnsureKubeadmInitWaitControlPlanePhase,
p.EnsureKubeadmInitUploadConfigPhase,
p.EnsureKubeadmInitUploadCertsPhase,
p.EnsureKubeadmInitBootstrapTokenPhase,
p.EnsureKubeadmInitAddonPhase,
p.EnsureJoinControlePlane,
p.EnsureMarkControlPlane,
p.EnsureRebuildEtcd,
p.EnsureDeployCni,
p.EnsureRebuildControlPlane,
p.EnsureExtKubeconfig,
p.EnsurePostInstallHook,
},
UpdateHandlers: []clusterprovider.Handler{
p.EnsureExtKubeconfig,
p.EnsureMasterNode,
p.EnsureDeployCni,
p.EnsureRebuildEtcd,
p.EnsureRebuildControlPlane,
p.EnsureRenewCerts,
p.EnsureAPIServerCert,
p.EnsureMetricsServer,
},
}
return p, nil
}
func (p *Provider) RegisterHandler(mux *mux.PathRecorderMux) {
prefix := "/provider/" + strings.ToLower(p.Name())
mux.HandleFunc(path.Join(prefix, "ping"), p.ping)
}
func (p *Provider) Validate(ctx *common.ClusterContext) field.ErrorList {
return validation.ValidateCluster(ctx)
}
func (p *Provider) PreCreate(ctx *common.ClusterContext) error {
if ctx.Cluster.Spec.Version == "" {
ctx.Cluster.Spec.Version = constants.K8sVersions[0]
}
if ctx.Cluster.Spec.ClusterCIDR == "" {
ctx.Cluster.Spec.ClusterCIDR = "10.244.0.0/16"
}
if ctx.Cluster.Spec.NetworkDevice == "" {
ctx.Cluster.Spec.NetworkDevice = "eth0"
}
if ctx.Cluster.Spec.CRIType == "" {
ctx.Cluster.Spec.CRIType = devopsv1.ContainerdCRI
}
if ctx.Cluster.Spec.Features.IPVS == nil {
ctx.Cluster.Spec.Features.IPVS = pointer.ToBool(true)
}
if ctx.Cluster.Spec.Properties.MaxClusterServiceNum == nil && ctx.Cluster.Spec.ServiceCIDR == nil {
ctx.Cluster.Spec.Properties.MaxClusterServiceNum = pointer.ToInt32(256)
}
if ctx.Cluster.Spec.Properties.MaxNodePodNum == nil {
ctx.Cluster.Spec.Properties.MaxNodePodNum = pointer.ToInt32(256)
}
if ctx.Cluster.Spec.Features.SkipConditions == nil {
ctx.Cluster.Spec.Features.SkipConditions = p.Cfg.Feature.SkipConditions
}
if ctx.Cluster.Spec.Etcd == nil {
ctx.Cluster.Spec.Etcd = &devopsv1.Etcd{Local: &devopsv1.LocalEtcd{}}
}
return nil
}