Updated on Nov 29,2022
%%{ init: { 'flowchart': { 'curve': 'basis' } } }%%
flowchart BT
hashtable.h --> ht(hashtable.cc):::source
log.h --> lg(log.cc):::source
mempool.h:::header --> mp(mempool.cc):::source
piekv.h --> op(operation.cc):::source
communication.h --> main(main.cc):::source
communication.h:::header --> cp(communication.cc):::source
subgraph Headers
basic_hash.h:::header --> cuckoo.h
cuckoo.h:::header --> hashtable.h
hashtable.h:::header --> log.h
log.h:::header --> piekv.h
mempool.h --> basic_hash.h
piekv.h:::header --> communication.h
util.h:::header --> basic_hash.h
end
basic_hash.h --> bp(basic_hash.cc):::source
log.h --> cc(cuckoo.cc):::source
%%util.h --> zipf.h
%%zipf.h --> NO_INCLUDE
classDef header fill:#eef,font-family:arias,font-size:16px,font-weight:300;
classDef source fill:#bcf,font-family:arias,font-size:16px;
classDef diff fill:#f82,font-size:15px;
ACEKV&MICA/build 路径下运行
make -j若当前路径下无Makefile,先运行
cmake ..memc3在Memc3/build 路径下同理
ACEKV&MICA/src/basic_hash.cc
-
#define RUN_MICA该宏定义生效则运行MICA-t,注释掉则运行ACEKV
-
#define MEMC3_EVICT该宏定义生效则按照memc3的方式进行evict,默认关
-
#define USE_COUNTER该宏定义生效则使用counter,默认开
-
#define CLEANUP该宏定义生效则mica进行cleanup,默认开
-
#define RELOAD该宏定义生效则在get miss后进行reload,默认开
-
#define RELOAD_RECORD该宏定义生效则将reload按set统计,默认关,测cuckoopath时打开
-
#define LATENCY该宏定义用于测试latency,默认关
-
#define size8 // #define size64 // #define size256 // #define size512在测试不同kvsize时切换使用
ACEKV&MICA/build/main
| -a | 设定自适应阈值(如-a 50) |
|---|---|
| -f | 参数为2时监控并显示系统运行状态(一般都要设) |
| -l | 设定每个线程log大小(30为1GB) |
| -t | 设定hash table总大小(30为1GB) |
执行./go脚本将直接在控制台运行
执行./explog脚本将在运行的同时把输出结果写入log文件
ACEKV&MICA/data/cuckoo_path
cuckoo path相关图片及数据,最终图片在kick_num文件夹内
ACEKV&MICA/data/hitrate
hitrate相关图片及数据,最终图片在worktable_enough前缀文件夹内,最终数据在lllatest前缀文件夹内
ACEKV&MICA/data/latency_cdf
latency相关图片及数据,最终图片output文件夹内
ACEKV&MICA/data/loadfactor
load factor相关图片及数据,最终图片在ttl后缀文件夹内
ACEKV&MICA/data/mica_weakness/mica_evict
mica evict相关图片及数据,展示mica本身的劣势,最终图片valid_evict_new文件夹内
ACEKV&MICA/data/threshold_table
threshold相关数据,用mean.sh脚本加上对应文件夹可计算对应平均值
ACEKV&MICA/data/throughput
throughput相关图片及数据,最终图片和数据在latest后缀文件夹内
上述大部分图片都使用最近的drawplus.sh生成
Memc3/data/……
memc3相关数据在上述路径
Client文件夹下运行
make clean && make -jClient/client.cpp
-
#define ratiomemc3该宏定义生效则按照memc3的数据量运行
-
##define ratioacekv该宏定义生效则按照acekv和mica的数据量运行
-
#define GHR该宏定义用于测试hitrate,注释则用于测试tput
其他宏定义无需关心
Client/build/app/client
| -n | 设定发送总数(参考go.sh中设置即可,一般设置偏大) |
|---|---|
| r | 设定读取操作的占比(读写均衡即为0.5) |
| -t | 选择发送系统类型,16为mica,8为acekv/memc3 |
| -u/z | 设定数据类型,-u即uniform,-z即skewed,默认后者 |
| -l | 设定发送kvsize |
| -w | 按照hash table大小设置数据发送比例,默认100,即100% |
建议使用./go.sh + pu/pz/mu/mz 便捷发送
p用于acekv/memc3,m用于mica