elasticsearch-drain 0.1.3 → 0.1.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/elasticsearch/drain/cli.rb +13 -4
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f8ea42452ed3c9c4a2516200330ef800a9fa2007
|
4
|
+
data.tar.gz: cd16505372008cd84b97b59966c9b86b51549869
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 841c98585ebdadf034e477efe7ed9778ff678e28550ac1c3a888269065583fea64edb0dc2d2f26f241bef717f76e4b9c87f211d877a7cc569e426872b69c6e87
|
7
|
+
data.tar.gz: 17a299d9f3697306fcfd80116ba4e26777c7cc3e8d6b54d6abc10d82bec3d4b43a6e01c263087aaee1a23e6730305b8308f9f37ba55262ad28a15fa7d1ce0d62
|
@@ -76,10 +76,17 @@ module Elasticsearch
|
|
76
76
|
@active_nodes = nodes unless options[:continue]
|
77
77
|
|
78
78
|
drain_nodes(nodes)
|
79
|
-
remove_nodes(nodes)
|
79
|
+
deleted_nodes = remove_nodes(nodes)
|
80
80
|
|
81
81
|
# Remove the drained nodes from the list of active_nodes
|
82
|
-
|
82
|
+
say_status "deleted nodes", "deleted_nodes=#{deleted_nodes}", "green"
|
83
|
+
say_status "pre-subtract", "active_nodes=#{active_nodes}", "green"
|
84
|
+
|
85
|
+
deleted_nodes.each do |deleted_node|
|
86
|
+
@active_nodes.delete_if { |n| n.ipaddress == deleted_node.ipaddress }
|
87
|
+
end
|
88
|
+
|
89
|
+
say_status "post-subtract", "active_nodes=#{active_nodes}", "green"
|
83
90
|
|
84
91
|
unless active_nodes.empty?
|
85
92
|
say_status 'Drain Nodes', "#{active_nodes.length} nodes remaining", :green
|
@@ -119,9 +126,8 @@ module Elasticsearch
|
|
119
126
|
(min_size - nodes.length) <= 0 ? 0 : (min_size - nodes.length)
|
120
127
|
else
|
121
128
|
# Removing the nodes will result in the min_size being violated
|
122
|
-
desired_capacity - nodes.length
|
129
|
+
(desired_capacity - nodes.length) <= 0 ? 0 : (desired_capacity - nodes.length)
|
123
130
|
end
|
124
|
-
say_status 'Debug', "min_size = #{min_size}, desired_capacity = #{desired_capacity}, desired_min_size = #{desired_min_size}", :magenta
|
125
131
|
desired_min_size
|
126
132
|
end
|
127
133
|
|
@@ -143,6 +149,7 @@ module Elasticsearch
|
|
143
149
|
end
|
144
150
|
|
145
151
|
def remove_nodes(nodes) # rubocop:disable Metrics/MethodLength
|
152
|
+
deleted_nodes = []
|
146
153
|
while nodes.length > 0
|
147
154
|
sleep_time = wait_sleep_time
|
148
155
|
nodes.each do |instance|
|
@@ -152,6 +159,7 @@ module Elasticsearch
|
|
152
159
|
sleep sleep_time
|
153
160
|
else
|
154
161
|
next unless remove_node(instance)
|
162
|
+
deleted_nodes.push(nodes.select { |n| n.ipaddress == instance.ipaddress })
|
155
163
|
nodes.delete_if { |n| n.ipaddress == instance.ipaddress }
|
156
164
|
break if nodes.length < 1
|
157
165
|
say_status 'Waiting', 'Sleeping for 1 minute before removing the next node', :green
|
@@ -159,6 +167,7 @@ module Elasticsearch
|
|
159
167
|
end
|
160
168
|
end
|
161
169
|
end
|
170
|
+
deleted_nodes
|
162
171
|
end
|
163
172
|
|
164
173
|
def remove_node(instance) # rubocop:disable Metrics/MethodLength
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: elasticsearch-drain
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Andrew Thompson
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-08-
|
11
|
+
date: 2020-08-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|