From d98eabcf103339a2eaf2a305b98ad04632b691aa Mon Sep 17 00:00:00 2001 From: 9547 Date: Wed, 16 Dec 2020 15:31:27 +0800 Subject: [PATCH 1/2] Feature: don't reload prometheus if the scaled comp is itself (#989) * typo(cluster): nodesID -> nodesIDs * typo(*): role -> roles * fix(cluster/manager): exclude the scale-in node if scaled node were prom * tests(cluster): add prometheus scale-in/out case * chore(git): gitignore not used anymore * fix(tests/tools): wrong count * fix(tests/tiup-cluster): wait nodes after scale Co-authored-by: Allen Zhong Co-authored-by: SIGSEGV --- components/cluster/command/patch.go | 2 +- components/dm/command/patch.go | 2 +- pkg/cluster/manager/builder.go | 19 +++++++++++++------ pkg/cluster/manager/destroy.go | 5 ++++- pkg/cluster/manager/scale_in.go | 2 +- pkg/cluster/task/builder.go | 4 ++-- pkg/cluster/task/update_meta.go | 6 +++--- pkg/cluster/task/update_topology.go | 4 ++-- tests/tiup-cluster/script/scale_tools.sh | 12 ++++++++++++ tests/tiup-cluster/topo/.gitignore | 1 - .../topo/full_scale_in_prometheus.yaml | 3 +++ 11 files changed, 42 insertions(+), 18 deletions(-) delete mode 100644 tests/tiup-cluster/topo/.gitignore create mode 100644 tests/tiup-cluster/topo/full_scale_in_prometheus.yaml diff --git a/components/cluster/command/patch.go b/components/cluster/command/patch.go index 249006eef9..bfca649980 100644 --- a/components/cluster/command/patch.go +++ b/components/cluster/command/patch.go @@ -46,7 +46,7 @@ func newPatchCmd() *cobra.Command { cmd.Flags().BoolVar(&overwrite, "overwrite", false, "Use this package in the future scale-out operations") cmd.Flags().StringSliceVarP(&gOpt.Nodes, "node", "N", nil, "Specify the nodes") - cmd.Flags().StringSliceVarP(&gOpt.Roles, "role", "R", nil, "Specify the role") + cmd.Flags().StringSliceVarP(&gOpt.Roles, "role", "R", nil, "Specify the roles") cmd.Flags().Uint64Var(&gOpt.APITimeout, "transfer-timeout", 300, "Timeout in seconds when transferring PD and TiKV store leaders") return cmd } diff --git a/components/dm/command/patch.go b/components/dm/command/patch.go index a4ec859b2c..f212653859 100644 --- a/components/dm/command/patch.go +++ b/components/dm/command/patch.go @@ -46,6 +46,6 @@ func newPatchCmd() *cobra.Command { cmd.Flags().BoolVar(&overwrite, "overwrite", false, "Use this package in the future scale-out operations") cmd.Flags().StringSliceVarP(&gOpt.Nodes, "node", "N", nil, "Specify the nodes") - cmd.Flags().StringSliceVarP(&gOpt.Roles, "role", "R", nil, "Specify the role") + cmd.Flags().StringSliceVarP(&gOpt.Roles, "role", "R", nil, "Specify the roles") return cmd } diff --git a/pkg/cluster/manager/builder.go b/pkg/cluster/manager/builder.go index cd97912caf..476bcc8ef6 100644 --- a/pkg/cluster/manager/builder.go +++ b/pkg/cluster/manager/builder.go @@ -30,8 +30,8 @@ import ( "github.com/pingcap/tiup/pkg/set" ) -// Dynamic reload Prometheus configuration -func buildDynReloadPromTasks(topo spec.Topology) []task.Task { +// buildReloadPromTasks reloads Prometheus configuration +func buildReloadPromTasks(topo spec.Topology, nodes ...string) []task.Task { monitor := spec.FindComponent(topo, spec.ComponentPrometheus) if monitor == nil { return nil @@ -40,11 +40,18 @@ func buildDynReloadPromTasks(topo spec.Topology) []task.Task { if len(instances) == 0 { return nil } - var dynReloadTasks []task.Task + var tasks []task.Task + deletedNodes := set.NewStringSet(nodes...) for _, inst := range monitor.Instances() { - dynReloadTasks = append(dynReloadTasks, task.NewBuilder().SystemCtl(inst.GetHost(), inst.ServiceName(), "reload", true).Build()) + if deletedNodes.Exist(inst.ID()) { + continue + } + t := task.NewBuilder(). + SystemCtl(inst.GetHost(), inst.ServiceName(), "reload", true). + Build() + tasks = append(tasks, t) } - return dynReloadTasks + return tasks } func buildScaleOutTask( @@ -298,7 +305,7 @@ func buildScaleOutTask( return operator.Start(ctx, newPart, operator.Options{OptTimeout: gOpt.OptTimeout}, tlsCfg) }). Parallel(false, refreshConfigTasks...). - Parallel(false, buildDynReloadPromTasks(metadata.GetTopology())...) + Parallel(false, buildReloadPromTasks(metadata.GetTopology())...) if final != nil { final(builder, name, metadata) diff --git a/pkg/cluster/manager/destroy.go b/pkg/cluster/manager/destroy.go index 105c831512..179cff5cb5 100644 --- a/pkg/cluster/manager/destroy.go +++ b/pkg/cluster/manager/destroy.go @@ -133,7 +133,10 @@ func (m *Manager) DestroyTombstone( UpdateTopology(name, m.specManager.Path(name), clusterMeta, nodes) regenConfigTasks, _ := buildRegenConfigTasks(m, name, topo, base, nodes) - t := b.ParallelStep("+ Refresh instance configs", true, regenConfigTasks...).Parallel(true, buildDynReloadPromTasks(metadata.GetTopology())...).Build() + t := b. + ParallelStep("+ Refresh instance configs", true, regenConfigTasks...). + Parallel(true, buildReloadPromTasks(metadata.GetTopology())...). + Build() if err := t.Execute(task.NewContext()); err != nil { if errorx.Cast(err) != nil { // FIXME: Map possible task errors and give suggestions. diff --git a/pkg/cluster/manager/scale_in.go b/pkg/cluster/manager/scale_in.go index 7aa686fdd6..a255542916 100644 --- a/pkg/cluster/manager/scale_in.go +++ b/pkg/cluster/manager/scale_in.go @@ -92,7 +92,7 @@ func (m *Manager) ScaleIn( t := b. ParallelStep("+ Refresh instance configs", force, regenConfigTasks...). - Parallel(force, buildDynReloadPromTasks(metadata.GetTopology())...). + Parallel(force, buildReloadPromTasks(metadata.GetTopology(), nodes...)...). Build() if err := t.Execute(task.NewContext()); err != nil { diff --git a/pkg/cluster/task/builder.go b/pkg/cluster/task/builder.go index c605e39c29..a42dcc4d16 100644 --- a/pkg/cluster/task/builder.go +++ b/pkg/cluster/task/builder.go @@ -112,7 +112,7 @@ func (b *Builder) UpdateMeta(cluster string, metadata *spec.ClusterMeta, deleted b.tasks = append(b.tasks, &UpdateMeta{ cluster: cluster, metadata: metadata, - deletedNodesID: deletedNodeIds, + deletedNodeIDs: deletedNodeIds, }) return b } @@ -123,7 +123,7 @@ func (b *Builder) UpdateTopology(cluster, profile string, metadata *spec.Cluster metadata: metadata, cluster: cluster, profileDir: profile, - deletedNodesID: deletedNodeIds, + deletedNodeIDs: deletedNodeIds, }) return b } diff --git a/pkg/cluster/task/update_meta.go b/pkg/cluster/task/update_meta.go index 8fe272d1c7..813255892d 100644 --- a/pkg/cluster/task/update_meta.go +++ b/pkg/cluster/task/update_meta.go @@ -25,7 +25,7 @@ import ( type UpdateMeta struct { cluster string metadata *spec.ClusterMeta - deletedNodesID []string + deletedNodeIDs []string } // Execute implements the Task interface @@ -33,7 +33,7 @@ type UpdateMeta struct { // the other callers point to this field by a pointer, // so we should update the original topology directly, and don't make a copy func (u *UpdateMeta) Execute(ctx *Context) error { - deleted := set.NewStringSet(u.deletedNodesID...) + deleted := set.NewStringSet(u.deletedNodeIDs...) topo := u.metadata.Topology tidbServers := make([]spec.TiDBSpec, 0) @@ -154,5 +154,5 @@ func (u *UpdateMeta) Rollback(ctx *Context) error { // String implements the fmt.Stringer interface func (u *UpdateMeta) String() string { - return fmt.Sprintf("UpdateMeta: cluster=%s, deleted=`'%s'`", u.cluster, strings.Join(u.deletedNodesID, "','")) + return fmt.Sprintf("UpdateMeta: cluster=%s, deleted=`'%s'`", u.cluster, strings.Join(u.deletedNodeIDs, "','")) } diff --git a/pkg/cluster/task/update_topology.go b/pkg/cluster/task/update_topology.go index 6def0bcdd7..562db6184d 100644 --- a/pkg/cluster/task/update_topology.go +++ b/pkg/cluster/task/update_topology.go @@ -17,7 +17,7 @@ type UpdateTopology struct { cluster string profileDir string metadata *spec.ClusterMeta - deletedNodesID []string + deletedNodeIDs []string } // String implements the fmt.Stringer interface @@ -41,7 +41,7 @@ func (u *UpdateTopology) Execute(ctx *Context) error { topo := u.metadata.Topology - deleted := set.NewStringSet(u.deletedNodesID...) + deleted := set.NewStringSet(u.deletedNodeIDs...) var ops []clientv3.Op var instances []spec.Instance diff --git a/tests/tiup-cluster/script/scale_tools.sh b/tests/tiup-cluster/script/scale_tools.sh index 32e7b05d32..5d2349ddc1 100755 --- a/tests/tiup-cluster/script/scale_tools.sh +++ b/tests/tiup-cluster/script/scale_tools.sh @@ -36,8 +36,12 @@ function scale_tools() { if [ $test_tls = true ]; then total_sub_one=18 + total=19 + total_add_one=20 else total_sub_one=21 + total=22 + total_add_one=23 fi echo "start scale in pump" @@ -70,6 +74,14 @@ function scale_tools() { topo=./topo/full_scale_in_grafana.yaml tiup-cluster $client --yes scale-out $name $topo + echo "start scale out prometheus" + topo=./topo/full_scale_in_prometheus.yaml + tiup-cluster $client --yes scale-out $name $topo + wait_instance_num_reach $name $total_add_one $native_ssh + echo "start scale in prometheus" + tiup-cluster $client --yes scale-in $name -N n2:9090 + wait_instance_num_reach $name $total $native_ssh + # make sure grafana dashboards has been set to default (since the full_sale_in_grafana.yaml didn't provide a local dashboards dir) ! tiup-cluster $client exec $name -N n1 --command "grep magic-string-for-test /home/tidb/deploy/grafana-3000/dashboards/tidb.json" diff --git a/tests/tiup-cluster/topo/.gitignore b/tests/tiup-cluster/topo/.gitignore deleted file mode 100644 index 1e82fc7deb..0000000000 --- a/tests/tiup-cluster/topo/.gitignore +++ /dev/null @@ -1 +0,0 @@ -*.yaml diff --git a/tests/tiup-cluster/topo/full_scale_in_prometheus.yaml b/tests/tiup-cluster/topo/full_scale_in_prometheus.yaml new file mode 100644 index 0000000000..533238961e --- /dev/null +++ b/tests/tiup-cluster/topo/full_scale_in_prometheus.yaml @@ -0,0 +1,3 @@ +monitoring_servers: + - host: n2 + rule_dir: /tmp/local/prometheus From 87f670b70e8d7bddc0e6c45b8d12958a961c9a73 Mon Sep 17 00:00:00 2001 From: SIGSEGV Date: Thu, 17 Dec 2020 14:45:27 +0800 Subject: [PATCH 2/2] Correct mirror init flag (#997) --- cmd/mirror.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmd/mirror.go b/cmd/mirror.go index 411336156d..61ff7344a2 100644 --- a/cmd/mirror.go +++ b/cmd/mirror.go @@ -626,7 +626,7 @@ current working directory (".") will be used.`, }, } - cmd.Flags().StringVarP(&keyDir, "", "i", "", "Path to write the private key file") + cmd.Flags().StringVarP(&keyDir, "key-dir", "k", "", "Path to write the private key file") return cmd }