2016-11-09 2 views
3

lmdb 환경을 만들 때 맵 크기를 지정할 수 있습니다. 어떤 시점에서 얼마나 많은지도 크기가 소모되었는지 판단하는 방법이 있습니까?lmdb : 남은 공간을 확인하는 방법은 무엇입니까?

다른 말로하면 공간 부족 문제를 해결하기 위해 얼마나 많은 여유 공간이 남아 있는지 알아야합니다.

내가 생각할 수있는 유일한 방법은 모든 데이터베이스를 거쳐 mdb_env_stat를 사용하여 분기, 리프 및 오버플로 페이지 수를 얻는 것입니다. 모든 dbs (시간 페이지 크기)에 걸쳐이 모든 것을 합산하고 현재 맵 크기와 비교하십시오. 사용 된 공간을 계산하는 올바른 방법입니까?

답변

4

실제로 내가 사용하고있는 접근법입니다 (그리고 내가 찾을 수있는 유일한 방법입니다). 모든 데이터베이스의

:

MDB_stat stat; 
mdb_stat(d->transaction, d->dbi, &stat); 
auto dbSize = stat.ms_psize * (stat.ms_leaf_pages + stat.ms_branch_pages + stat.ms_overflow_pages); 
관련 문제