cephprovider

package
v3.4.7+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 27, 2016 License: GPL-3.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

View Source
const ADDR_LOCK_SIZE = 0x1000000000

4096 blocks per addr lock

View Source
const ADDR_OBJ_SIZE = 0x0001000000
View Source
const MAX_EXPECTED_OBJECT_SIZE = 20485

Just over the DBSIZE

View Source
const METADATA_BASE = 0xFF00000000000000

We know we won't get any addresses here, because this is the relocation base as well

View Source
const NUM_RHANDLES = 200
View Source
const OFFSET_MASK = 0xFFFFFF
View Source
const RADOS_CACHE_SIZE = NUM_RHANDLES * 2

The number of RADOS blocks to cache (up to 16MB each, probably only 1.6MB each)

View Source
const R_ADDRMASK = ^((uint64(1) << 20) - 1)

We are caching 1MB blocks for read, so the address should have the bottom 20 bits clear

View Source
const R_CHUNKSIZE = 1 << 20
View Source
const R_OFFSETMASK = (uint64(1) << 20) - 1
View Source
const SEGCACHE_SIZE = 1024
View Source
const WCACHE_SIZE = 1 << 20

1MB for write cache, I doubt we will ever hit this tbh

This is how many uuid/address pairs we will keep to facilitate appending to segments instead of creating new ones.

Variables

This section is empty.

Functions

func UUIDSliceToArr

func UUIDSliceToArr(id []byte) [16]byte

Types

type CacheItem

type CacheItem struct {
	// contains filtered or unexported fields
}

type CephCache

type CephCache struct {
	// contains filtered or unexported fields
}

type CephSegment

type CephSegment struct {
	// contains filtered or unexported fields
}

func (*CephSegment) BaseAddress

func (seg *CephSegment) BaseAddress() uint64

Returns the address of the first free word in the segment when it was locked

func (*CephSegment) Flush

func (seg *CephSegment) Flush()

Block until all writes are complete. Note this does not imply a flush of the underlying files.

func (*CephSegment) Unlock

func (seg *CephSegment) Unlock()

Unlocks the segment for the StorageProvider to give to other consumers Implies a flush

func (*CephSegment) Write

func (seg *CephSegment) Write(uuid []byte, address uint64, data []byte) (uint64, error)

Writes a slice to the segment, returns immediately Returns nil if op is OK, otherwise ErrNoSpace or ErrInvalidArgument It is up to the implementer to work out how to report no space immediately The uint64 is the address to be used for the next write

type CephStorageProvider

type CephStorageProvider struct {
	// contains filtered or unexported fields
}

func (*CephStorageProvider) CreateDatabase

func (sp *CephStorageProvider) CreateDatabase(opts map[string]string) error

Called to create the database for the first time

func (*CephStorageProvider) Initialize

func (sp *CephStorageProvider) Initialize(opts map[string]string)

Called at startup of a normal run

func (*CephStorageProvider) LockSegment

func (sp *CephStorageProvider) LockSegment(uuid []byte) bprovider.Segment

Lock a segment, or block until a segment can be locked Returns a Segment struct Implicit unchecked assumption: you cannot lock more than one segment for a given uuid (without unlocking them in between). It will break segcache

func (*CephStorageProvider) Read

func (sp *CephStorageProvider) Read(uuid []byte, address uint64, buffer []byte) []byte

Read the blob into the given buffer

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL