Sha256: c82c8310636976cf586e5bed6904e1dcf12cd8b5040c0d30dd7625aa6372c806

Contents?: true

Size: 1.5 KB

Versions: 25

Compression:

Stored size: 1.5 KB

Contents

# encoding: utf-8
# Copyright 2014 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

25 entries across 25 versions & 1 rubygems

Version Path
aerospike-2.3.0 lib/aerospike/task/index_task.rb
aerospike-2.2.1 lib/aerospike/task/index_task.rb
aerospike-2.2.0 lib/aerospike/task/index_task.rb
aerospike-2.1.1 lib/aerospike/task/index_task.rb
aerospike-2.1.0 lib/aerospike/task/index_task.rb
aerospike-2.0.0 lib/aerospike/task/index_task.rb
aerospike-1.0.12 lib/aerospike/task/index_task.rb
aerospike-1.0.11 lib/aerospike/task/index_task.rb
aerospike-1.0.10 lib/aerospike/task/index_task.rb
aerospike-1.0.9 lib/aerospike/task/index_task.rb
aerospike-1.0.8 lib/aerospike/task/index_task.rb
aerospike-1.0.7 lib/aerospike/task/index_task.rb
aerospike-1.0.6 lib/aerospike/task/index_task.rb
aerospike-1.0.5 lib/aerospike/task/index_task.rb
aerospike-1.0.4 lib/aerospike/task/index_task.rb
aerospike-1.0.3 lib/aerospike/task/index_task.rb
aerospike-1.0.2 lib/aerospike/task/index_task.rb
aerospike-1.0.1 lib/aerospike/task/index_task.rb
aerospike-1.0.0 lib/aerospike/task/index_task.rb
aerospike-0.1.6 lib/aerospike/task/index_task.rb