3
我計劃在BerkeleyDB JE數據庫中插入大量的唯一密鑰(〜3E9)。優化BerkeleyDB JE數據庫
這些密鑰將具有固定長度(〜10字節),但值將具有可變長度。數據庫不會是事務性的。
你會建議EnvironmentConfig和DatabaseConfig哪些參數用於優化數據庫的大小和速度?
非常感謝,
皮埃爾
我計劃在BerkeleyDB JE數據庫中插入大量的唯一密鑰(〜3E9)。優化BerkeleyDB JE數據庫
這些密鑰將具有固定長度(〜10字節),但值將具有可變長度。數據庫不會是事務性的。
你會建議EnvironmentConfig和DatabaseConfig哪些參數用於優化數據庫的大小和速度?
非常感謝,
皮埃爾
OK,我找到了解決辦法使用工具com.sleepycat.je.util.DbCacheSize包裝成的BerkeleyDB-JE
java -cp je-4.0.103.jar com.sleepycat.je.util.DbCacheSize -records 3000000000 -key 8
Inputs: records=3000000000 keySize=8 dataSize=-1 nodeMax=128 binMax=128 density=80% overhead=10%
=== Cache Sizing Summary ===
Cache Size Btree Size Description
--------------- --------------- -----------
206,574,616,257 185,917,154,632 Minimum, internal nodes only
231,821,163,884 208,639,047,496 Maximum, internal nodes only
To get leaf node sizing specify -data
=== Memory Usage by Btree Level ===
Minimum Bytes Maximum Bytes Nodes Level
--------------- --------------- ---------- -----
184,101,562,500 206,601,562,500 29,296,875 1
1,797,864,968 2,017,591,304 286,102 2
17,551,212 19,696,236 2,793 3
169,668 190,404 27 4
6,284 7,052 1 5