Sha256: d7cc78f777ad9046015909de7e50caf301d9bf6165053a8a3c72ea5756b615da
Contents?: true
Size: 1.51 KB
Versions: 12
Compression:
Stored size: 1.51 KB
Contents
# encoding: utf-8 # Copyright 2014-2020 Aerospike, Inc. # # Portions may be licensed to Aerospike, Inc. under one or more contributor # license agreements. # # 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. require 'thread' require 'time' require 'aerospike/task/task' module Aerospike private class IndexTask < Task MATCHER = /.*load_pct=(?<load_pct>\d+(\.\d+)?).*/ def initialize(cluster, namespace, index_name, done=false) super(cluster, done) @namespace = namespace @index_name = index_name self end private def all_nodes_done? command = "sindex/#{@namespace}/#{@index_name}" nodes = @cluster.nodes nodes.each do |node| conn = node.get_connection(1) response_map = Info.request(conn, command) _, response = response_map.first match = response.to_s.match(MATCHER) load = match.nil? ? nil : match[:load_pct] return false if load && (0...100).include?(load.to_f) end return true end end # class end # module
Version data entries
12 entries across 12 versions & 1 rubygems