Ruby 脚本在存储 riak 对象时挂起
Ruby script hangs when storing riak object
我正在尝试执行 "Seven Databases in Seven Weeks" 书中的脚本 hotel.rb。为了使其与 riak 2.1.1 一起工作,我不得不更改客户端的创建,除此之外它与可以从书籍网站下载的脚本相同:
require 'rubygems'
require 'riak'
STYLES = %w{single double queen king suite}
client = Riak::Client.new(:nodes => [
{:host => 'localhost', :pb_port => 10017},
{:host => 'localhost', :pb_port => 10027},
{:host => 'localhost', :pb_port => 10037}
])
bucket = client.bucket('rooms')
# Create 100 floors to the building
for floor in 1..100
current_rooms_block = floor * 100
puts "Making rooms #{current_rooms_block} - #{current_rooms_block + 100}"
# Put 100 rooms on each floor (huge hotel!)
for room in 1...100
# Create a unique room number as the key
ro = Riak::RObject.new(bucket, (current_rooms_block + room))
# Randomly grab a room style, and make up a capacity
style = STYLES[rand(STYLES.length)]
capacity = rand(8) + 1
# Store the room information as a JSON value
ro.content_type = "application/json"
ro.data = {'style' => style, 'capacity' => capacity}
puts "before storing"
ro.store # Line 42
puts "after storing"
end
end
这是我得到的输出:
chris@desktop:~/Downloads$ ruby hotel.rb
Making rooms 100 - 200
before storing
在 ro 上调用存储方法时,脚本似乎挂起。
本书使用riak 1.0.2版本,我使用riak 2.1.1.
更新:尝试使用 Ruby 1.9.3 和 Ruby 2.0.0。我正在使用 ubuntu 14.04.
更新 2:我使用了 http 端口而不是 pb 端口,现在我在调用商店时得到以下信息:
/var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:105:in `dup': can't dup Fixnum (TypeError)
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:105:in `maybe_encode'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:18:in `dump_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake_protobuffs_backend.rb:136:in `store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:412:in `block in store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:357:in `block in recover_from'
from /var/lib/gems/2.0.0/gems/innertube-1.0.2/lib/innertube.rb:127:in `take'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:355:in `recover_from'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:327:in `protobuffs'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:411:in `store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/robject.rb:144:in `store'
from ../7dbs-code/code/riak/hotel.rb:42:in `block (2 levels) in <main>'
from ../7dbs-code/code/riak/hotel.rb:28:in `each'
from ../7dbs-code/code/riak/hotel.rb:28:in `block in <main>'
from ../7dbs-code/code/riak/hotel.rb:24:in `each'
from ../7dbs-code/code/riak/hotel.rb:24:in `<main>'
较新的客户端要求键名是字符串。
ro = Riak::RObject.new(bucket, "#{current_rooms_block + room}")
仅供参考,这是 riak-client-2.2.1 和 ruby 1.9.3
的工作示例
require 'rubygems'
require 'riak'
STYLES = %w{single double queen king suite}
client = Riak::Client.new(:nodes => [
{:host => 'localhost', :http_port => 8098}
])
bucket = client.bucket('rooms')
# Create 100 floors to the building
for floor in 1..100
current_rooms_block = floor * 100
puts "Making rooms #{current_rooms_block} - #{current_rooms_block + 100}"
# Put 100 rooms on each floor (huge hotel!)
for room in 1...100
# Create a unique room number as the key
ro = Riak::RObject.new(bucket, "#{current_rooms_block + room}")
# Randomly grab a room style, and make up a capacity
style = STYLES[rand(STYLES.length)]
capacity = rand(8) + 1
# Store the room information as a JSON value
ro.content_type = "application/json"
ro.data = {'style' => style, 'capacity' => capacity}
ro.store
end
end
我正在尝试执行 "Seven Databases in Seven Weeks" 书中的脚本 hotel.rb。为了使其与 riak 2.1.1 一起工作,我不得不更改客户端的创建,除此之外它与可以从书籍网站下载的脚本相同:
require 'rubygems'
require 'riak'
STYLES = %w{single double queen king suite}
client = Riak::Client.new(:nodes => [
{:host => 'localhost', :pb_port => 10017},
{:host => 'localhost', :pb_port => 10027},
{:host => 'localhost', :pb_port => 10037}
])
bucket = client.bucket('rooms')
# Create 100 floors to the building
for floor in 1..100
current_rooms_block = floor * 100
puts "Making rooms #{current_rooms_block} - #{current_rooms_block + 100}"
# Put 100 rooms on each floor (huge hotel!)
for room in 1...100
# Create a unique room number as the key
ro = Riak::RObject.new(bucket, (current_rooms_block + room))
# Randomly grab a room style, and make up a capacity
style = STYLES[rand(STYLES.length)]
capacity = rand(8) + 1
# Store the room information as a JSON value
ro.content_type = "application/json"
ro.data = {'style' => style, 'capacity' => capacity}
puts "before storing"
ro.store # Line 42
puts "after storing"
end
end
这是我得到的输出:
chris@desktop:~/Downloads$ ruby hotel.rb
Making rooms 100 - 200
before storing
在 ro 上调用存储方法时,脚本似乎挂起。 本书使用riak 1.0.2版本,我使用riak 2.1.1.
更新:尝试使用 Ruby 1.9.3 和 Ruby 2.0.0。我正在使用 ubuntu 14.04.
更新 2:我使用了 http 端口而不是 pb 端口,现在我在调用商店时得到以下信息:
/var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:105:in `dup': can't dup Fixnum (TypeError)
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:105:in `maybe_encode'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake/object_methods.rb:18:in `dump_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client/beefcake_protobuffs_backend.rb:136:in `store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:412:in `block in store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:357:in `block in recover_from'
from /var/lib/gems/2.0.0/gems/innertube-1.0.2/lib/innertube.rb:127:in `take'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:355:in `recover_from'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:327:in `protobuffs'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/client.rb:411:in `store_object'
from /var/lib/gems/2.0.0/gems/riak-client-2.2.1/lib/riak/robject.rb:144:in `store'
from ../7dbs-code/code/riak/hotel.rb:42:in `block (2 levels) in <main>'
from ../7dbs-code/code/riak/hotel.rb:28:in `each'
from ../7dbs-code/code/riak/hotel.rb:28:in `block in <main>'
from ../7dbs-code/code/riak/hotel.rb:24:in `each'
from ../7dbs-code/code/riak/hotel.rb:24:in `<main>'
较新的客户端要求键名是字符串。
ro = Riak::RObject.new(bucket, "#{current_rooms_block + room}")
仅供参考,这是 riak-client-2.2.1 和 ruby 1.9.3
的工作示例require 'rubygems'
require 'riak'
STYLES = %w{single double queen king suite}
client = Riak::Client.new(:nodes => [
{:host => 'localhost', :http_port => 8098}
])
bucket = client.bucket('rooms')
# Create 100 floors to the building
for floor in 1..100
current_rooms_block = floor * 100
puts "Making rooms #{current_rooms_block} - #{current_rooms_block + 100}"
# Put 100 rooms on each floor (huge hotel!)
for room in 1...100
# Create a unique room number as the key
ro = Riak::RObject.new(bucket, "#{current_rooms_block + room}")
# Randomly grab a room style, and make up a capacity
style = STYLES[rand(STYLES.length)]
capacity = rand(8) + 1
# Store the room information as a JSON value
ro.content_type = "application/json"
ro.data = {'style' => style, 'capacity' => capacity}
ro.store
end
end