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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 8f9122250f3be77882bb0ce4c14aa3de03eba351
4
- data.tar.gz: ea15747daa99591d805e3582366e149e37e0f673
3
+ metadata.gz: f8ea42452ed3c9c4a2516200330ef800a9fa2007
4
+ data.tar.gz: cd16505372008cd84b97b59966c9b86b51549869
5
5
  SHA512:
6
- metadata.gz: 017452105174c3c2c12a073b70580f61ada317653273a8951f89f310b8c51dccacf456b54dfe6554610879f6f5721995e58db26b69daa23fcff08eeb92bced30
7
- data.tar.gz: 09e9cae06b18aa446a527e2612796af13b17d65549125a35e61717b13890e7b26ae76cc6a1f0cef7180cae50cd6b365ce5be625294ea2f0dd5f3dc11d6b918f6
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
- @active_nodes -= nodes
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.3
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-17 00:00:00.000000000 Z
11
+ date: 2020-08-20 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler