// Copyright 2015, 2016 Ethcore (UK) Ltd. // This file is part of Parity. // Parity is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // Parity is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Parity. If not, see <http://www.gnu.org/licenses/>. use std::cmp::max; const MIN_BC_CACHE_MB: u32 = 4; const MIN_DB_CACHE_MB: u32 = 2; const MIN_BLOCK_QUEUE_SIZE_LIMIT_MB: u32 = 16; const DEFAULT_BLOCK_QUEUE_SIZE_LIMIT_MB: u32 = 50; const DEFAULT_TRACE_CACHE_SIZE: u32 = 20; const DEFAULT_STATE_CACHE_SIZE: u32 = 25; /// Configuration for application cache sizes. /// All values are represented in MB. #[derive(Debug, PartialEq)] pub struct CacheConfig { /// Size of rocksDB cache. Almost all goes to the state column. db: u32, /// Size of blockchain cache. blockchain: u32, /// Size of transaction queue cache. queue: u32, /// Size of traces cache. traces: u32, /// Size of the state cache. state: u32, } impl Default for CacheConfig { fn default() -> Self { CacheConfig::new(64, 8, DEFAULT_BLOCK_QUEUE_SIZE_LIMIT_MB, DEFAULT_STATE_CACHE_SIZE) } } impl CacheConfig { /// Creates new cache config with cumulative size equal `total`. pub fn new_with_total_cache_size(total: u32) -> Self { CacheConfig { db: total * 7 / 10, blockchain: total / 10, queue: DEFAULT_BLOCK_QUEUE_SIZE_LIMIT_MB, traces: DEFAULT_TRACE_CACHE_SIZE, state: total * 2 / 10, } } /// Creates new cache config with gitven details. pub fn new(db: u32, blockchain: u32, queue: u32, state: u32) -> Self { CacheConfig { db: db, blockchain: blockchain, queue: queue, traces: DEFAULT_TRACE_CACHE_SIZE, state: state, } } /// Size of db cache for blockchain. pub fn db_blockchain_cache_size(&self) -> u32 { max(MIN_DB_CACHE_MB, self.db / 4) } /// Size of db cache for state. pub fn db_state_cache_size(&self) -> u32 { max(MIN_DB_CACHE_MB, self.db * 3 / 4) } /// Size of block queue size limit pub fn queue(&self) -> u32 { max(self.queue, MIN_BLOCK_QUEUE_SIZE_LIMIT_MB) } /// Size of the blockchain cache. pub fn blockchain(&self) -> u32 { max(self.blockchain, MIN_BC_CACHE_MB) } /// Size of the traces cache. pub fn traces(&self) -> u32 { self.traces } /// Size of the state cache. pub fn state(&self) -> u32 { self.state * 3 / 4 } /// Size of the jump-tables cache. pub fn jump_tables(&self) -> u32 { self.state / 4 } } #[cfg(test)] mod tests { use super::CacheConfig; #[test] fn test_cache_config_constructor() { let config = CacheConfig::new_with_total_cache_size(200); assert_eq!(config.db, 140); assert_eq!(config.blockchain(), 20); assert_eq!(config.queue(), 50); assert_eq!(config.state(), 30); assert_eq!(config.jump_tables(), 10); } #[test] fn test_cache_config_db_cache_sizes() { let config = CacheConfig::new_with_total_cache_size(400); assert_eq!(config.db, 280); assert_eq!(config.db_blockchain_cache_size(), 70); assert_eq!(config.db_state_cache_size(), 210); } #[test] fn test_cache_config_default() { assert_eq!(CacheConfig::default(), CacheConfig::new(64, 8, super::DEFAULT_BLOCK_QUEUE_SIZE_LIMIT_MB, super::DEFAULT_STATE_CACHE_SIZE)); } }