forked from labring/sealos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjoin.go
70 lines (59 loc) · 2.16 KB
/
join.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
// Copyright © 2019 NAME HERE <EMAIL ADDRESS>
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package cmd
import (
"os"
"github.com/spf13/cobra"
"github.com/fanux/sealos/install"
"github.com/wonderivan/logger"
)
// joinCmd represents the join command
var joinCmd = &cobra.Command{
Use: "join",
Short: "Simplest way to join your kubernets HA cluster",
Long: `sealos join --node 192.168.0.5`,
PreRun: func(cmd *cobra.Command, args []string) {
if len(install.MasterIPs) == 0 && len(install.NodeIPs) == 0 {
logger.Error("this command is join feature,master and node is empty at the same time.please check your args in command.")
cmd.Help()
os.Exit(0)
}
},
Run: JoinCmdFunc,
}
func init() {
rootCmd.AddCommand(joinCmd)
joinCmd.Flags().StringSliceVar(&install.MasterIPs, "master", []string{}, "kubernetes multi-master ex. 192.168.0.5-192.168.0.5")
joinCmd.Flags().StringSliceVar(&install.NodeIPs, "node", []string{}, "kubernetes multi-nodes ex. 192.168.0.5-192.168.0.5")
joinCmd.Flags().IntVar(&install.Vlog, "vlog", 0, "kubeadm log level")
}
func JoinCmdFunc (cmd *cobra.Command, args []string) {
beforeNodes := install.ParseIPs(install.NodeIPs)
beforeMasters := install.ParseIPs(install.MasterIPs)
c := &install.SealConfig{}
err := c.Load(cfgFile)
if err != nil {
logger.Error(err)
c.ShowDefaultConfig()
os.Exit(0)
}
cfgNodes := append(c.Masters, c.Nodes...)
joinNodes := append(beforeNodes, beforeMasters...)
if ok, node := deleteOrJoinNodeIsExistInCfgNodes(joinNodes, cfgNodes); ok {
logger.Error(`[%s] has already exist in your cluster. please check.`, node)
os.Exit(-1)
}
install.BuildJoin(beforeMasters, beforeNodes)
c.Dump(cfgFile)
}