python">import lmdb
import os
import argparse
import gevent
import gevent.queue
TEMP_PATH="/dev/shm/test"
#TEMP_PATH="/dev/shm/"
env = lmdb.Environment('./lm_db/',readonly = False, map_size=1048576 * 1024, metasync=False, sync=True, map_async=True)
files = os.listdir(TEMP_PATH)
queue = gevent.queue.Queue()
map(queue.put, files)
def lmdbstore(db ,queue = queue):
with db.begin(write=True) as lmdb_txn:
try:
for i in xrange(3000):
item = queue.get()
key = item
value = file(os.path.join(TEMP_PATH, item)).read()
lmdb_txn.put( key , value )
print(i, item)
except StopIteration as exc:
print( str(exc))
def delete(db):
with db.begin( write = True ) as txn:
cursor = txn.cursor()
for idx,data in enumerate( cursor.iternext_nodup() ):
txn.delete(data)
def query(db):
with db.begin( write = True) as txn:
cursor = txn.cursor()
for idx, data in enumerate( cursor.iternext_nodup()):
print(idx,data)
if __name__ == '__main__':
#query( env )
lmdbstore(env, queue)
env.sync(True)
标签:python