200 lines
7.5 KiB
Go
200 lines
7.5 KiB
Go
package utils
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"k8s.io/klog/v2"
|
|
|
|
"github.com/karmada-io/karmada/pkg/karmadactl/cmdinit/options"
|
|
)
|
|
|
|
const (
|
|
// https://github.com/karmada-io/karmada/blob/master/artifacts/agent
|
|
karmadaAgent = `---
|
|
apiVersion: v1
|
|
kind: Namespace
|
|
metadata:
|
|
name: karmada-system
|
|
---
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
kind: ClusterRole
|
|
metadata:
|
|
name: karmada-agent
|
|
rules:
|
|
- apiGroups: ['*']
|
|
resources: ['*']
|
|
verbs: ['*']
|
|
- nonResourceURLs: ['*']
|
|
verbs: ["get"]
|
|
---
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
kind: ClusterRoleBinding
|
|
metadata:
|
|
name: karmada-agent
|
|
roleRef:
|
|
apiGroup: rbac.authorization.k8s.io
|
|
kind: ClusterRole
|
|
name: karmada-agent
|
|
subjects:
|
|
- kind: ServiceAccount
|
|
name: karmada-agent-sa
|
|
namespace: karmada-system
|
|
---
|
|
apiVersion: v1
|
|
kind: ServiceAccount
|
|
metadata:
|
|
name: karmada-agent-sa
|
|
namespace: karmada-system
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: karmada-agent
|
|
namespace: karmada-system
|
|
labels:
|
|
app: karmada-agent
|
|
spec:
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
app: karmada-agent
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: karmada-agent
|
|
spec:
|
|
serviceAccountName: karmada-agent-sa
|
|
tolerations:
|
|
- key: node-role.kubernetes.io/master
|
|
operator: Exists
|
|
containers:
|
|
- name: karmada-agent
|
|
image: swr.ap-southeast-1.myhuaweicloud.com/karmada/karmada-agent:latest
|
|
command:
|
|
- /bin/karmada-agent
|
|
- --karmada-kubeconfig=/etc/kubeconfig/karmada-kubeconfig
|
|
- --karmada-context=%s
|
|
- --cluster-name={member_cluster_name}
|
|
- --cluster-api-endpoint={member_cluster_api_endpoint}
|
|
- --cluster-status-update-frequency=10s
|
|
- --bind-address=0.0.0.0
|
|
- --secure-port=10357
|
|
- --v=4
|
|
livenessProbe:
|
|
httpGet:
|
|
path: /healthz
|
|
port: 10357
|
|
scheme: HTTP
|
|
failureThreshold: 3
|
|
initialDelaySeconds: 15
|
|
periodSeconds: 15
|
|
timeoutSeconds: 5
|
|
volumeMounts:
|
|
- name: kubeconfig
|
|
mountPath: /etc/kubeconfig
|
|
volumes:
|
|
- name: kubeconfig
|
|
secret:
|
|
secretName: karmada-kubeconfig`
|
|
|
|
estimator = `apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
name: karmada-scheduler-estimator-{{member_cluster_name}}
|
|
namespace: karmada-system
|
|
labels:
|
|
cluster: {{member_cluster_name}}
|
|
spec:
|
|
replicas: 1
|
|
selector:
|
|
matchLabels:
|
|
app: karmada-scheduler-estimator-{{member_cluster_name}}
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app: karmada-scheduler-estimator-{{member_cluster_name}}
|
|
spec:
|
|
tolerations:
|
|
- key: node-role.kubernetes.io/master
|
|
operator: Exists
|
|
containers:
|
|
- name: karmada-scheduler-estimator
|
|
image: swr.ap-southeast-1.myhuaweicloud.com/karmada/karmada-scheduler-estimator:latest
|
|
imagePullPolicy: IfNotPresent
|
|
command:
|
|
- /bin/karmada-scheduler-estimator
|
|
- --kubeconfig=/etc/{{member_cluster_name}}-kubeconfig
|
|
- --cluster-name={{member_cluster_name}}
|
|
volumeMounts:
|
|
- name: member-kubeconfig
|
|
subPath: {{member_cluster_name}}-kubeconfig
|
|
mountPath: /etc/{{member_cluster_name}}-kubeconfig
|
|
volumes:
|
|
- name: member-kubeconfig
|
|
secret:
|
|
secretName: {{member_cluster_name}}-kubeconfig
|
|
---
|
|
apiVersion: v1
|
|
kind: Service
|
|
metadata:
|
|
name: karmada-scheduler-estimator-{{member_cluster_name}}
|
|
namespace: karmada-system
|
|
labels:
|
|
cluster: {{member_cluster_name}}
|
|
spec:
|
|
selector:
|
|
app: karmada-scheduler-estimator-{{member_cluster_name}}
|
|
ports:
|
|
- protocol: TCP
|
|
port: 10352
|
|
targetPort: 10352`
|
|
)
|
|
|
|
// GenExamples Generate sample files
|
|
func GenExamples(path, parentCommand, printRegisterCommand string) {
|
|
karmadaAgentStr := fmt.Sprintf(karmadaAgent, options.ClusterName)
|
|
if err := BytesToFile(path, "karmada-agent.yaml", []byte(karmadaAgentStr)); err != nil {
|
|
klog.Warning(err)
|
|
}
|
|
|
|
// https://github.com/karmada-io/karmada/blob/master/artifacts/deploy/karmada-scheduler-estimator.yaml
|
|
if err := BytesToFile(path, "karmada-scheduler-estimator.yaml", []byte(estimator)); err != nil {
|
|
klog.Warning(err)
|
|
}
|
|
|
|
fmt.Printf(`
|
|
------------------------------------------------------------------------------------------------------
|
|
█████ ████ █████████ ███████████ ██████ ██████ █████████ ██████████ █████████
|
|
░░███ ███░ ███░░░░░███ ░░███░░░░░███ ░░██████ ██████ ███░░░░░███ ░░███░░░░███ ███░░░░░███
|
|
░███ ███ ░███ ░███ ░███ ░███ ░███░█████░███ ░███ ░███ ░███ ░░███ ░███ ░███
|
|
░███████ ░███████████ ░██████████ ░███░░███ ░███ ░███████████ ░███ ░███ ░███████████
|
|
░███░░███ ░███░░░░░███ ░███░░░░░███ ░███ ░░░ ░███ ░███░░░░░███ ░███ ░███ ░███░░░░░███
|
|
░███ ░░███ ░███ ░███ ░███ ░███ ░███ ░███ ░███ ░███ ░███ ███ ░███ ░███
|
|
█████ ░░████ █████ █████ █████ █████ █████ █████ █████ █████ ██████████ █████ █████
|
|
░░░░░ ░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░ ░░░░░░░░░░ ░░░░░ ░░░░░
|
|
------------------------------------------------------------------------------------------------------
|
|
Karmada is installed successfully.
|
|
|
|
Register Kubernetes cluster to Karmada control plane.
|
|
|
|
Register cluster with 'Push' mode
|
|
|
|
Step 1: Use "%[2]s join" command to register the cluster to Karmada control plane. --cluster-kubeconfig is kubeconfig of the member cluster.
|
|
(In karmada)~# MEMBER_CLUSTER_NAME="cat ~/.kube/config | grep current-context | sed 's/: /\n/g'| sed '1d'"
|
|
(In karmada)~# %[2]s --kubeconfig %[1]s/karmada-apiserver.config join ${MEMBER_CLUSTER_NAME} --cluster-kubeconfig=$HOME/.kube/config
|
|
|
|
Step 2: Show members of karmada
|
|
(In karmada)~# kubectl --kubeconfig %[1]s/karmada-apiserver.config get clusters
|
|
|
|
|
|
Register cluster with 'Pull' mode
|
|
|
|
Step 1: Use "%[2]s register" command to register the cluster to Karmada control plane. "--cluster-name" is set to cluster of current-context by default.
|
|
(In member cluster)~# %[2]s%[3]s
|
|
|
|
Step 2: Show members of karmada
|
|
(In karmada)~# kubectl --kubeconfig %[1]s/karmada-apiserver.config get clusters
|
|
|
|
`, path, parentCommand, printRegisterCommand)
|
|
}
|