Class: Couchbase::Bucket
- Inherits:
-
Object
- Object
- Couchbase::Bucket
- Includes:
- Async, Operations
- Defined in:
- lib/couchbase/bucket.rb
Constant Summary collapse
- DEFAULT_OPTIONS =
{ type: nil, quiet: false, hostname: 'localhost', port: 8091, pool: 'default', bucket: 'default', password: '', engine: nil, default_ttl: 0, async: false, default_arithmetic_init: 0, default_flags: 0, default_format: :document, default_observe_timeout: 2_500_000, on_error: nil, on_connect: nil, timeout: 0, environment: nil, key_prefix: nil, node_list: nil, destroying: 0, connected: 0, on_connect_proc: nil, async_disconnect_hook_set: 0, connected: false }.freeze
Instance Attribute Summary collapse
-
#bucket ⇒ Object
Returns the value of attribute bucket.
-
#client ⇒ Object
readonly
Returns the value of attribute client.
-
#default_arithmetic_init ⇒ Object
Returns the value of attribute default_arithmetic_init.
-
#default_format ⇒ Object
Returns the value of attribute default_format.
-
#default_ttl ⇒ Object
Returns the value of attribute default_ttl.
-
#hostname ⇒ Object
Returns the value of attribute hostname.
-
#key_prefix ⇒ Object
readonly
Returns the value of attribute key_prefix.
-
#password ⇒ Object
Returns the value of attribute password.
-
#pool ⇒ Object
Returns the value of attribute pool.
-
#port ⇒ Object
Returns the value of attribute port.
-
#quiet ⇒ Object
Returns the value of attribute quiet.
-
#timeout ⇒ Object
Returns the value of attribute timeout.
-
#transcoder ⇒ Object
Returns the value of attribute transcoder.
-
#username ⇒ Object
Returns the value of attribute username.
Instance Method Summary collapse
- #authority ⇒ Object
- #base_url ⇒ Object
-
#cas(key, options = {}) {|value| ... } ⇒ Fixnum
(also: #compare_and_swap)
Compare and swap value.
- #connect ⇒ Object (also: #reconnect)
- #connected? ⇒ Boolean
-
#create_periodic_timer(interval, &block) ⇒ Couchbase::Timer
Create and register periodic timer.
-
#create_timer(interval, &block) ⇒ Couchbase::Timer
Create and register one-shot timer.
- #disconnect ⇒ Object
-
#flush {|ret| ... } ⇒ true
Delete contents of the bucket.
- #host ⇒ Object
-
#initialize(url = nil, options = {}) ⇒ Bucket
constructor
Initialize new Bucket.
-
#observe_and_wait(*keys, &block) ⇒ Fixnum, Hash<String, Fixnum>
Wait for persistence condition.
- #on_connect(&block) ⇒ Object
- #on_error(&block) ⇒ Object
- #quiet? ⇒ Boolean
- #url ⇒ Object
- #version ⇒ Object
Methods included from Async
#async, #async=, #async?, #async_queue, #end_async_queue, #run, #run_async, #running, #running=, #running?
Methods included from Operations
Constructor Details
#initialize(url, options = {}) ⇒ Bucket #initialize(options = {}) ⇒ Bucket
Initialize new Bucket.
164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 |
# File 'lib/couchbase/bucket.rb', line 164 def initialize(url = nil, = {}) = if url.is_a? String fail ArgumentError.new unless url =~ /^http:\/\// uri = URI.new(url) { hostname: uri.host, port: uri.port }. merge(path_to_pool_and_bucket(uri.path)) elsif url.nil? {} else url end = Couchbase.() = DEFAULT_OPTIONS.merge().merge() .each_pair do |key, value| instance_variable_set("@#{key}", value) end @transcoders = { document: Transcoder::Document.new, marshal: Transcoder::Marshal.new, plain: Transcoder::Plain.new } connect unless async? end |
Instance Attribute Details
#bucket ⇒ Object
Returns the value of attribute bucket.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def bucket @bucket end |
#client ⇒ Object (readonly)
Returns the value of attribute client.
42 43 44 |
# File 'lib/couchbase/bucket.rb', line 42 def client @client end |
#default_arithmetic_init ⇒ Object
Returns the value of attribute default_arithmetic_init.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def default_arithmetic_init @default_arithmetic_init end |
#default_format ⇒ Object
Returns the value of attribute default_format.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def default_format @default_format end |
#default_ttl ⇒ Object
Returns the value of attribute default_ttl.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def default_ttl @default_ttl end |
#hostname ⇒ Object
Returns the value of attribute hostname.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def hostname @hostname end |
#key_prefix ⇒ Object (readonly)
Returns the value of attribute key_prefix.
42 43 44 |
# File 'lib/couchbase/bucket.rb', line 42 def key_prefix @key_prefix end |
#password ⇒ Object
Returns the value of attribute password.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def password @password end |
#pool ⇒ Object
Returns the value of attribute pool.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def pool @pool end |
#port ⇒ Object
Returns the value of attribute port.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def port @port end |
#quiet ⇒ Object
Returns the value of attribute quiet.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def quiet @quiet end |
#timeout ⇒ Object
Returns the value of attribute timeout.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def timeout @timeout end |
#transcoder ⇒ Object
Returns the value of attribute transcoder.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def transcoder @transcoder end |
#username ⇒ Object
Returns the value of attribute username.
38 39 40 |
# File 'lib/couchbase/bucket.rb', line 38 def username @username end |
Instance Method Details
#authority ⇒ Object
224 225 226 |
# File 'lib/couchbase/bucket.rb', line 224 def "#{hostname}:#{port}" end |
#base_url ⇒ Object
228 229 230 |
# File 'lib/couchbase/bucket.rb', line 228 def base_url "http://#{}/pools" end |
#cas(key, options = {}) {|value| ... } ⇒ Fixnum Also known as: compare_and_swap
Compare and swap value.
Reads a key’s value from the server and yields it to a block. Replaces the key’s value with the result of the block as long as the key hasn’t been updated in the meantime, otherwise raises Error::KeyExists. CAS stands for “compare and swap”, and avoids the need for manual key mutexing. Read more info here:
In asynchronous mode it will yield result twice, first for Bucket#get with Result#operation equal to :get
and second time for Bucket#set with Result#operation equal to :set
.
331 332 333 334 335 336 337 338 339 340 341 342 343 |
# File 'lib/couchbase/bucket.rb', line 331 def cas(key, = {}) if async? block = Proc.new get(key) do |ret| val = block.call(ret) # get new value from caller set(ret.key, val, .merge(:cas => ret.cas, &block)) end else val, flags, ver = get(key, :extended => true) val = yield(val) # get new value from caller set(key, val, .merge(:cas => ver)) end end |
#connect ⇒ Object Also known as: reconnect
201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 |
# File 'lib/couchbase/bucket.rb', line 201 def connect uris = if @node_list Array(@node_list).map { |n| URI.new(n) } else Array(URI.new(base_url)) end begin builder = CouchbaseConnectionFactoryBuilder.new builder.setTranscoder(transcoder) connection_factory = builder.buildCouchbaseConnection(uris, bucket.to_java_string, password.to_java_string) @client = CouchbaseClient.new(connection_factory) @connected = true rescue Java::ComCouchbaseClientVbucket::ConfigurationException fail Couchbase::Error::Auth, 'Couchbase configurations are incorrect.' rescue java.net.ConnectException => e fail Couchbase::Error::Connect end self end |
#connected? ⇒ Boolean
236 237 238 |
# File 'lib/couchbase/bucket.rb', line 236 def connected? @connected end |
#create_periodic_timer(interval, &block) ⇒ Couchbase::Timer
Create and register periodic timer
397 398 399 |
# File 'lib/couchbase/bucket.rb', line 397 def create_periodic_timer(interval, &block) Timer.new(self, interval, :periodic => true, &block) end |
#create_timer(interval, &block) ⇒ Couchbase::Timer
Create and register one-shot timer
390 391 392 |
# File 'lib/couchbase/bucket.rb', line 390 def create_timer(interval, &block) Timer.new(self, interval, &block) end |
#disconnect ⇒ Object
240 241 242 243 244 245 246 247 248 249 |
# File 'lib/couchbase/bucket.rb', line 240 def disconnect if connected? @client.shutdown(3, TimeUnit::SECONDS) @client = nil @connection_factory = nil @connected = false else fail Couchbase::Error::Connect end end |
#flush {|ret| ... } ⇒ true
Delete contents of the bucket
371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 |
# File 'lib/couchbase/bucket.rb', line 371 def flush if !async? && block_given? sync_block_error end req = make_http_request("/pools/default/buckets/#{bucket}/controller/doFlush", :type => :management, :method => :post, :extended => true) res = nil req.on_body do |r| res = r res.instance_variable_set("@operation", :flush) yield(res) if block_given? end req.continue true end |
#host ⇒ Object
197 198 199 |
# File 'lib/couchbase/bucket.rb', line 197 def host hostname end |
#observe_and_wait(*keys, &block) ⇒ Fixnum, Hash<String, Fixnum>
Wait for persistence condition
This operation is useful when some confidence needed regarding the state of the keys. With two parameters :replicated
and :persisted
it allows to set up the waiting rule.
425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 |
# File 'lib/couchbase/bucket.rb', line 425 def observe_and_wait(*keys, &block) = {:timeout => default_observe_timeout} .update(keys.pop) if keys.size > 1 && keys.last.is_a?(Hash) () if block && !async? raise ArgumentError, "synchronous mode doesn't support callbacks" end if keys.size == 0 raise ArgumentError, "at least one key is required" end if keys.size == 1 && keys[0].is_a?(Hash) key_cas = keys[0] else key_cas = keys.flatten.reduce({}) do |h, kk| h[kk] = nil # set CAS to nil h end end if async? do_observe_and_wait(key_cas, , &block) else res = do_observe_and_wait(key_cas, , &block) while res.nil? unless async? if keys.size == 1 && (keys[0].is_a?(String) || keys[0].is_a?(Symbol)) return res.values.first else return res end end end end |
#on_connect(&block) ⇒ Object
255 256 257 |
# File 'lib/couchbase/bucket.rb', line 255 def on_connect(&block) @on_connect = block end |
#on_error(&block) ⇒ Object
259 260 261 |
# File 'lib/couchbase/bucket.rb', line 259 def on_error(&block) @on_error = block end |
#quiet? ⇒ Boolean
193 194 195 |
# File 'lib/couchbase/bucket.rb', line 193 def quiet? !!quiet end |
#url ⇒ Object
232 233 234 |
# File 'lib/couchbase/bucket.rb', line 232 def url "http://#{}/pools/#{pool}/buckets/#{bucket}/" end |
#version ⇒ Object
263 264 265 266 267 268 269 |
# File 'lib/couchbase/bucket.rb', line 263 def version {}.tap do |hash| @client.getVersions.to_hash.each_pair do |ip, ver| hash[ip.to_s] = ver end end end |