Class: Couchbase::Management::BucketSettings

Inherits:
Object
  • Object
show all
Extended by:
Gem::Deprecate
Defined in:
lib/couchbase/management/bucket_manager.rb,
/Users/sergey.auseyau/code/couchbase-ruby-client/lib/couchbase/management/bucket_manager.rb
more...

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize {|self| ... } ⇒ BucketSettings

Returns a new instance of BucketSettings.

Yield Parameters:

[View source]

418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
# File 'lib/couchbase/management/bucket_manager.rb', line 418

def initialize
  @bucket_type = :couchbase
  @name = nil
  @minimum_durability_level = nil
  @healthy = true
  @flush_enabled = false
  @ram_quota_mb = 100
  @num_replicas = 1
  @replica_indexes = false
  @max_expiry = 0
  @compression_mode = :passive
  @conflict_resolution_type = :sequence_number
  @eviction_policy = :value_only
  @storage_backend = nil
  yield self if block_given?
end

Instance Attribute Details

#bucket_type:couchbase, ...

Returns the type of the bucket. Defaults to :couchbase.

Returns:

  • (:couchbase, :memcached, :ephemeral)

    the type of the bucket. Defaults to :couchbase


360
361
362
# File 'lib/couchbase/management/bucket_manager.rb', line 360

def bucket_type
  @bucket_type
end

#compression_mode:off, ...

Returns the compression mode to use.

Returns:

  • (:off, :passive, :active)

    the compression mode to use


389
390
391
# File 'lib/couchbase/management/bucket_manager.rb', line 389

def compression_mode
  @compression_mode
end

#conflict_resolution_type:timestamp, ...

Returns conflict resolution policy.

Returns:

  • (:timestamp, :sequence_number, :custom)

    conflict resolution policy


392
393
394
# File 'lib/couchbase/management/bucket_manager.rb', line 392

def conflict_resolution_type
  @conflict_resolution_type
end

#eviction_policy:full, ...

Eviction policy to use

:full

During ejection, only the value will be ejected (key and metadata will remain in memory). Value Ejection needs more system memory, but provides better performance than Full Ejection. This value is only valid for buckets of type :couchbase.

:value_only

During ejection, everything (including key, metadata, and value) will be ejected. Full Ejection reduces the memory overhead requirement, at the cost of performance. This value is only valid for buckets of type :couchbase.

:no_eviction

Couchbase Server keeps all data until explicitly deleted, but will reject any new data if you reach the quota (dedicated memory) you set for your bucket. This value is only valid for buckets of type :ephemeral.

:not_recently_used

When the memory quota is reached, Couchbase Server ejects data that has not been used recently. This value is only valid for buckets of type :ephemeral.

Returns:

  • (:full, :value_only, :no_eviction, :not_recently_used)

    the eviction policy to use


383
384
385
# File 'lib/couchbase/management/bucket_manager.rb', line 383

def eviction_policy
  @eviction_policy
end

#flush_enabledBoolean

Returns whether or not flush should be enabled on the bucket. Defaults to false.

Returns:

  • (Boolean)

    whether or not flush should be enabled on the bucket. Defaults to false.


348
349
350
# File 'lib/couchbase/management/bucket_manager.rb', line 348

def flush_enabled
  @flush_enabled
end

#max_expiryInteger

Returns value of TTL (expiration) in seconds for new documents created without expiration.

Returns:

  • (Integer)

    value of TTL (expiration) in seconds for new documents created without expiration


386
387
388
# File 'lib/couchbase/management/bucket_manager.rb', line 386

def max_expiry
  @max_expiry
end

#minimum_durability_levelnil, ...

Returns the minimum durability level.

Returns:

  • (nil, :none, :majority, :majority_and_persist_to_active, :persist_to_majority)

    the minimum durability level


395
396
397
# File 'lib/couchbase/management/bucket_manager.rb', line 395

def minimum_durability_level
  @minimum_durability_level
end

#nameString

Returns name of the bucket.

Returns:

  • (String)

    name of the bucket


345
346
347
# File 'lib/couchbase/management/bucket_manager.rb', line 345

def name
  @name
end

#num_replicasInteger

Returns number of replicas for documents.

Returns:

  • (Integer)

    number of replicas for documents


354
355
356
# File 'lib/couchbase/management/bucket_manager.rb', line 354

def num_replicas
  @num_replicas
end

#ram_quota_mbInteger

Returns RAM quota in megabytes for the bucket.

Returns:

  • (Integer)

    RAM quota in megabytes for the bucket


351
352
353
# File 'lib/couchbase/management/bucket_manager.rb', line 351

def ram_quota_mb
  @ram_quota_mb
end

#replica_indexesBoolean

Returns whether replica indexes should be enabled for the bucket.

Returns:

  • (Boolean)

    whether replica indexes should be enabled for the bucket


357
358
359
# File 'lib/couchbase/management/bucket_manager.rb', line 357

def replica_indexes
  @replica_indexes
end

#storage_backendnil, ...

Returns the type of the storage backend of the bucket.

Returns:

  • (nil, :couchstore, :magma)

    the type of the storage backend of the bucket


363
364
365
# File 'lib/couchbase/management/bucket_manager.rb', line 363

def storage_backend
  @storage_backend
end

Instance Method Details

#ejection_policyObject

Deprecated.

Use #eviction_policy instead

[View source]

404
405
406
# File 'lib/couchbase/management/bucket_manager.rb', line 404

def ejection_policy
  @eviction_policy
end

#ejection_policy=(val) ⇒ Object

Deprecated.

Use #eviction_policy= instead

[View source]

411
412
413
# File 'lib/couchbase/management/bucket_manager.rb', line 411

def ejection_policy=(val)
  @eviction_policy = val
end