Sha256: d9f54612dda94a0915a18e93b7fbf1c7109458828e552a841ed4b75e1ba923bf

Contents?: true

Size: 1.29 KB

Versions: 2

Compression:

Stored size: 1.29 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?
        begin
          yield(self)
        ensure
          close
        end
      end
    end

    def close
      return unless handle
      log("close")
      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-ffi19-1.3 lib/ceph-ruby/cluster.rb
ceph-ruby-ffi19-1.2 lib/ceph-ruby/cluster.rb