setting up blockstoremanager

This commit is contained in:
benbierens 2023-03-14 10:46:33 +01:00
parent 7023bf586b
commit 004d96089f
No known key found for this signature in database
GPG Key ID: FE44815D96D0A1AA
6 changed files with 94 additions and 41 deletions

View File

@ -26,7 +26,7 @@ import ./node
import ./conf import ./conf
import ./rng import ./rng
import ./rest/api import ./rest/api
import ./stores import ./stores/blockstoremanager
import ./blockexchange import ./blockexchange
import ./utils/fileutils import ./utils/fileutils
import ./erasure import ./erasure
@ -46,8 +46,7 @@ type
config: CodexConf config: CodexConf
restServer: RestServerRef restServer: RestServerRef
codexNode: CodexNodeRef codexNode: CodexNodeRef
repoStore: RepoStore blockStoreManager: BlockStoreManager
maintenance: BlockMaintainer
CodexPrivateKey* = libp2p.PrivateKey # alias CodexPrivateKey* = libp2p.PrivateKey # alias
@ -95,12 +94,11 @@ proc bootstrapInteractions(config: CodexConf, repo: RepoStore): Future[Contracts
proc start*(s: CodexServer) {.async.} = proc start*(s: CodexServer) {.async.} =
notice "Starting codex node" notice "Starting codex node"
await s.repoStore.start() await s.blockStoreManager.start()
s.restServer.start() s.restServer.start()
s.codexNode.contracts = await bootstrapInteractions(s.config, s.repoStore) s.codexNode.contracts = await bootstrapInteractions(s.config, s.repoStore)
await s.codexNode.start() await s.codexNode.start()
s.maintenance.start()
let let
# TODO: Can't define these as constants, pity # TODO: Can't define these as constants, pity
@ -136,8 +134,7 @@ proc stop*(s: CodexServer) {.async.} =
await allFuturesThrowing( await allFuturesThrowing(
s.restServer.stop(), s.restServer.stop(),
s.codexNode.stop(), s.codexNode.stop(),
s.repoStore.stop(), s.blockStoreManager.stop())
s.maintenance.stop())
s.runHandle.complete() s.runHandle.complete()
@ -157,13 +154,6 @@ proc new*(T: type CodexServer, config: CodexConf, privateKey: CodexPrivateKey):
.withTcpTransport({ServerFlags.ReuseAddr}) .withTcpTransport({ServerFlags.ReuseAddr})
.build() .build()
var
cache: CacheStore = nil
if config.cacheSize > 0:
cache = CacheStore.new(cacheSize = config.cacheSize * MiB)
## Is unused?
let let
discoveryDir = config.dataDir / CodexDhtNamespace discoveryDir = config.dataDir / CodexDhtNamespace
@ -188,29 +178,14 @@ proc new*(T: type CodexServer, config: CodexConf, privateKey: CodexPrivateKey):
wallet = WalletRef.new(EthPrivateKey.random()) wallet = WalletRef.new(EthPrivateKey.random())
network = BlockExcNetwork.new(switch) network = BlockExcNetwork.new(switch)
repoData = case config.repoKind blockStoreManager = BlockStoreManager.new(config)
of repoFS: Datastore(FSDatastore.new($config.dataDir, depth = 5) blockStore = blockStoreManager.getBlockStore()
.expect("Should create repo file data store!"))
of repoSQLite: Datastore(SQLiteDatastore.new($config.dataDir)
.expect("Should create repo SQLite data store!"))
repoStore = RepoStore.new(
repoDs = repoData,
metaDs = SQLiteDatastore.new(config.dataDir / CodexMetaNamespace)
.expect("Should create meta data store!"),
quotaMaxBytes = config.storageQuota.uint,
blockTtl = config.blockTtlSeconds.seconds)
maintenance = BlockMaintainer.new(
repoStore,
interval = config.blockMaintenanceIntervalSeconds.seconds,
numberOfBlocksPerInterval = config.blockMaintenanceNumberOfBlocks)
peerStore = PeerCtxStore.new() peerStore = PeerCtxStore.new()
pendingBlocks = PendingBlocksManager.new() pendingBlocks = PendingBlocksManager.new()
blockDiscovery = DiscoveryEngine.new(repoStore, peerStore, network, discovery, pendingBlocks) blockDiscovery = DiscoveryEngine.new(blockStore, peerStore, network, discovery, pendingBlocks)
engine = BlockExcEngine.new(repoStore, wallet, network, blockDiscovery, peerStore, pendingBlocks) engine = BlockExcEngine.new(blockStore, wallet, network, blockDiscovery, peerStore, pendingBlocks)
store = NetworkStore.new(engine, repoStore) store = NetworkStore.new(engine, blockStore)
erasure = Erasure.new(store, leoEncoderProvider, leoDecoderProvider) erasure = Erasure.new(store, leoEncoderProvider, leoDecoderProvider)
codexNode = CodexNodeRef.new(switch, store, engine, erasure, discovery) codexNode = CodexNodeRef.new(switch, store, engine, erasure, discovery)
restServer = RestServerRef.new( restServer = RestServerRef.new(
@ -225,5 +200,4 @@ proc new*(T: type CodexServer, config: CodexConf, privateKey: CodexPrivateKey):
config: config, config: config,
codexNode: codexNode, codexNode: codexNode,
restServer: restServer, restServer: restServer,
repoStore: repoStore, blockStoreManager: blockStoreManager)
maintenance: maintenance)

View File

@ -195,7 +195,7 @@ type
name: "block-mn" }: int name: "block-mn" }: int
cacheSize* {. cacheSize* {.
desc: "The size in MiB of the block cache, 0 disables the cache - might help on slow hardrives" desc: "Size in MiB of the in-RAM block cache, 0 disables the cache - might help on slow hardrives"
defaultValue: 0 defaultValue: 0
defaultValueDesc: "0" defaultValueDesc: "0"
name: "cache-size" name: "cache-size"

2
codex/consts.nim Normal file
View File

@ -0,0 +1,2 @@
const
MiB* = 1024 * 1024

View File

@ -0,0 +1,79 @@
## Nim-Codex
## Copyright (c) 2023 Status Research & Development GmbH
## Licensed under either of
## * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
## * MIT license ([LICENSE-MIT](LICENSE-MIT))
## at your option.
## This file may not be copied, modified, or distributed except according to
## those terms.
import pkg/upraises
push: {.upraises: [].}
import pkg/chronos
import pkg/chronicles
import pkg/datastore
import ../node
import ../conf
import ../rng
import ../rest/api
import ../blockexchange
import ../utils/fileutils
import ../erasure
import ../discovery
import ../contracts
import ../utils/addrutils
import ../namespaces
import ../conf
import ./blockstore
import ./repostore
import ./maintenance
type
BlockStoreManager* = ref object of RootObj
repoStore: RepoStore
maintenance: BlockMaintainer
blockStore: BlockStore
proc start*(self: BlockStoreManager): Future[void] {.async.} =
await self.repoStore.start()
self.maintenance.start()
proc stop*(self: BlockStoreManager): Future[void] {.async.} =
await self.repoStore.stop()
await self.maintenance.stop()
proc getBlockStore*(self: BlockStoreManager): BlockStore =
self.blockStore
proc createRepoStore(config: CodexConf): RepoStore =
RepoStore.new(
repoDs = Datastore(FSDatastore.new($config.dataDir, depth = 5).expect("Should create repo data store!")),
metaDs = SQLiteDatastore.new(config.dataDir / CodexMetaNamespace).expect("Should create meta data store!"),
quotaMaxBytes = config.storageQuota.uint,
blockTtl = config.blockTtlSeconds.seconds)
proc createMaintenance(repoStore: RepoStore, config: CodexConf): BlockMaintainer =
BlockMaintainer.new(
repoStore,
interval = config.blockMaintenanceIntervalSeconds.seconds,
numberOfBlocksPerInterval = config.blockMaintenanceNumberOfBlocks)
proc getBlockStore(repoStore: RepoStore, config: CodexConf): BlockStore =
if config.cacheSize > 0:
return CacheStore.new(backingStore = repoStore, cacheSize = config.cacheSize * MiB)
return repoStore
func new*(T: type BlockStoreManager, config: CodexConf): T =
let
repoStore = createRepoStore(config)
maintenance = createMaintenance(repoStore, config)
blockStore = getBlockStore(repoStore, config)
T(
repoStore: repoStore,
maintenance: maintenance,
blockStore: blockStore)

View File

@ -21,8 +21,8 @@ import pkg/questionable
import pkg/questionable/results import pkg/questionable/results
import ./blockstore import ./blockstore
import ../consts
import ../chunker import ../chunker
import ../errors
import ../manifest import ../manifest
export blockstore export blockstore
@ -36,7 +36,6 @@ type
cache: LruCache[Cid, Block] cache: LruCache[Cid, Block]
const const
MiB* = 1024 * 1024
DefaultCacheSizeMiB* = 5 DefaultCacheSizeMiB* = 5
DefaultCacheSize* = DefaultCacheSizeMiB * MiB DefaultCacheSize* = DefaultCacheSizeMiB * MiB

View File

@ -22,8 +22,8 @@ import pkg/questionable
import pkg/questionable/results import pkg/questionable/results
import ./blockstore import ./blockstore
import ../consts
import ../chunker import ../chunker
import ../errors
import ../manifest import ../manifest
export blockstore export blockstore
@ -43,7 +43,6 @@ type
list: DoublyLinkedList[MemoryStoreNode] list: DoublyLinkedList[MemoryStoreNode]
const const
MiB* = 1024 * 1024
DefaultMemoryStoreCapacityMiB* = 5 DefaultMemoryStoreCapacityMiB* = 5
DefaultMemoryStoreCapacity* = DefaultMemoryStoreCapacityMiB * MiB DefaultMemoryStoreCapacity* = DefaultMemoryStoreCapacityMiB * MiB