Sha256: 569975d5f376f3440d10c56e76fdb49a13facdb95066a85c942b4cdc2b6cb350

Contents?: true

Size: 1.44 KB

Versions: 108

Compression:

Stored size: 1.44 KB

Contents

BENCHMARK_ROOT = File.dirname(__FILE__)
REDIS_ROOT = File.join(BENCHMARK_ROOT, "..", "lib")

$: << REDIS_ROOT
require 'redis'
require 'benchmark'

def show_usage
  puts <<-EOL
    Usage: worker.rb [read:write] <start_index> <end_index> <sleep_msec>
  EOL
end

def shift_from_argv
  value = ARGV.shift
  unless value
    show_usage
    exit -1
  end
  value
end

operation = shift_from_argv.to_sym
start_index = shift_from_argv.to_i
end_index = shift_from_argv.to_i
sleep_msec = shift_from_argv.to_i
sleep_duration = sleep_msec/1000.0

redis = Redis.new

case operation
  when :initialize

    start_index.upto(end_index) do |i|
      redis[i] = 0
    end

  when :clear

    start_index.upto(end_index) do |i|
      redis.delete(i)
    end

  when :read, :write

    puts "Starting to #{operation} at segment #{end_index + 1}"

    loop do
      t1 = Time.now
      start_index.upto(end_index) do |i|
        case operation
          when :read
            redis.get(i)
          when :write
            redis.incr(i)
          else
            raise "Unknown operation: #{operation}"
        end
        sleep sleep_duration
      end
      t2 = Time.now

      requests_processed = end_index - start_index
      time = t2 - t1
      puts "#{t2.strftime("%H:%M")} [segment #{end_index + 1}] : Processed #{requests_processed} requests in #{time} seconds - #{(requests_processed/time).round} requests/sec"
    end

  else
    raise "Unknown operation: #{operation}"
end

Version data entries

108 entries across 106 versions & 17 rubygems

Version Path
redis-3.0.1 benchmarking/worker.rb
classiccms-0.3.0 vendor/bundle/gems/redis-2.2.2/benchmarking/worker.rb
redis-3.0.0 benchmarking/worker.rb
resque-pool-0.3.0 vendor/bundle/ruby/1.8/gems/redis-2.2.2/benchmarking/worker.rb
redis-3.0.0.rc2 benchmarking/worker.rb
gorsuch-redis-3.0.0.rc1 benchmarking/worker.rb
resque-pool-0.3.0.beta.2 vendor/bundle/ruby/1.8/gems/redis-2.2.2/benchmarking/worker.rb
redis-3.0.0.rc1 benchmarking/worker.rb
yam-redis-with-retries-2.2.2.1 benchmarking/worker.rb
vanity-1.7.1 vendor/ruby/1.9.1/gems/redis-2.2.2/benchmarking/worker.rb
redis-2.2.2 benchmarking/worker.rb
redis-2.2.1 benchmarking/worker.rb
modesty-0.1.0 vendor/redis-rb/benchmarking/worker.rb
redis-2.2.0 benchmarking/worker.rb
lunar-0.4.1 vendor/redis/benchmarking/worker.rb
lunar-0.4.0 vendor/redis/benchmarking/worker.rb
lunar-0.3.0 vendor/redis/benchmarking/worker.rb
lunar-0.2.3 vendor/redis/benchmarking/worker.rb
lunar-0.2.2 vendor/redis/benchmarking/worker.rb
lunar-0.2.1 vendor/redis/benchmarking/worker.rb