Sha256: fdd091f6ab48386f953990f961666baa0dbb0e08b97774fc679027eaf36c3ff7
Contents?: true
Size: 1.26 KB
Versions: 2
Compression:
Stored size: 1.26 KB
Contents
module CephRuby class Cluster attr_accessor :handle def initialize(config_path = "/etc/ceph/ceph.conf") log("init lib rados #{Lib::Rados.version_string}, lib rbd #{Lib::Rbd.version_string}") handle_p = FFI::MemoryPointer.new(:pointer) ret = Lib::Rados.rados_create(handle_p, nil) raise SystemCallError.new("open of cluster failed", -ret) if ret < 0 self.handle = handle_p.get_pointer(0) setup_using_file(config_path) connect if block_given? yield(self) shutdown end end def shutdown return unless handle log("shutdown") Lib::Rados.rados_shutdown(handle) self.handle = nil end def pool(name, &block) Pool.new(self, name, &block) end # helper methods below def connect log("connect") ret = Lib::Rados.rados_connect(handle) raise SystemCallError.new("connect to cluster failed", -ret) if ret < 0 end def setup_using_file(path) log("setup_using_file #{path}") ret = Lib::Rados.rados_conf_read_file(handle, path) raise SystemCallError.new("setup of cluster from config file '#{path}' failed", -ret) if ret < 0 end def log(message) CephRuby.log("cluster #{message}") end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
ceph-ruby-1.1 | lib/ceph-ruby/cluster.rb |
ceph-ruby-1.0 | lib/ceph-ruby/cluster.rb |