data.vstor #
this module tries to re-implement z-stor in V, its not ready for production yet.
compression / encryption
- for now only as supported natively in vlang
- encryption is done by the blake192 hash
- encryption after compression
fn cache_get #
fn cache_get(zdb u32) !ZDBSTAT
fn new #
fn new() !VSTOR
fn slice_decode #
fn slice_decode(zo Slice) ![]u8
fetch the object from ZDB's decode the data back to binary stream
fn slice_new #
fn slice_new(data []u8, parts u8, parity u8) !Slice
encode data to ZStor Objecta parts is the relevant parts of data e.g. 16 parity is the overhead e.g. 4
struct FileMeta #
struct FileMeta {
mut:
slices []SliceMeta
pub mut:
name string
hash string // blake 192
compression_type CompressionType
encryption_type EncryptionType
}
the metadata as required for retrieving info from set of ZDB's this is the metadata which needs to be kept, otherwise data cannot be retrieved
struct Location #
struct Location {
pub mut:
farmid string // as in TFChain
name string
description string
}
Todo: define what is good way to specify a location, what do we have in TFChain
struct Slice #
struct Slice {
pub mut:
data [][]u8
parity u8 // nr of parity parts
crc32 []u32
}
the base object which is encoded and stored on set of ZDB is the data part, part of a file
fn (Slice) check #
fn (mut zo Slice) check(crc bool) !
verify that the dataobject has properly constructuted if crc set, then will recalculate crc to verify
struct SliceMeta #
struct SliceMeta {
pub mut:
zdbids []u32 // list of ZDB's used = the position in VSTOR.zdbs
zdbposition []u32 // the position in the ZDB (the key as u32)
crc32 []u32 // crc32 of each part in the zdb
}
the metadata as required for retrieving info from set of ZDB's
struct VSTOR #
struct VSTOR {
pub mut:
zdbs []ZDB
current_spread ZDBCurrentSpread
}
fn (VSTOR) location_new #
fn (mut vstor VSTOR) location_new(args Location) !Location
fn (VSTOR) monitor #
fn (mut vstor VSTOR) monitor() !
start a thread which will every hour do a check of all the known ZDBs info will be cached in redis eventually we will monitor other things too, so we know when system is no longer good
fn (VSTOR) spread_get #
fn (mut vstor VSTOR) spread_get(zdbid u32) !ZDBCurrentSpread
walk over the zdb stats, figure out which zdb's are best return those
fn (VSTOR) stor #
fn (mut vstor VSTOR) stor(mut path pathlib.Path) !
cut file in slices depending the current_spread encode & store the parts in the ZStor
fn (VSTOR) zdb_new #
fn (mut vstor VSTOR) zdb_new(args ZDB) !ZDB
fn (VSTOR) zdbstats_check #
fn (mut vstor VSTOR) zdbstats_check() !
fn (VSTOR) zdbstats_get #
fn (mut vstor VSTOR) zdbstats_get(zdbid u32) !ZDBSTAT
return ZDBSTAT object
struct ZDB #
struct ZDB {
pub mut:
location Location
address string
port u32
secret string
namespace string
stats []ZDBSTAT
}
import freeflowuniverse.crystallib.core.pathlib import time
struct ZDBCurrentSpread #
struct ZDBCurrentSpread {
pub mut:
spread []u32 // zdb's we are using
parts u8 // nr of parts data needs to be cut in e.g. 16
parity u8 // size of parity e.g. 4
last_check time.Time
slice_size_kb u32 // default 4 MB
compression_type CompressionType
encryption_type EncryptionType
}
is the current spread as used when storing new data to ZDB's
struct ZDBMeasurement #
struct ZDBMeasurement {
pub mut:
status ZDBSTATUS
latencies u32 // in millisecs
storage_capacity_gb u32 // amount of data stored in GB
storage_used_gb u32 // amount of data used in the zdb
time time.Time
}
struct ZDBSTAT #
struct ZDBSTAT {
pub mut:
id u32 // links to id of ZDB in VSTOR.zdbs
measurements []ZDBMeasurement
}
fn (ZDBSTAT) check #
fn (mut stat ZDBSTAT) check() !
execute on a check, remote poll the ZDB which returns the info only keep 12 checks
fn (ZDBSTAT) latency #
fn (mut stat ZDBSTAT) latency() u32
return latency averaged
fn (ZDBSTAT) storage_capacity #
fn (mut stat ZDBSTAT) storage_capacity() u32
fn (ZDBSTAT) storage_used #
fn (mut stat ZDBSTAT) storage_used() u32
fn (ZDBSTAT) percent_free #
fn (mut stat ZDBSTAT) percent_free() u8
return 100 for full, 0 for empty, 10 for 10%
fn (ZDBSTAT) cache_set #
fn (mut stat ZDBSTAT) cache_set() !
fn (ZDBSTAT) cache_get #
fn (mut stat ZDBSTAT) cache_get() !