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