最大で数百万の6文字の基本36文字列を保持する以下の動作を持つ永続キャッシュが必要です。 - クライアントがN個の文字列をキャッシュから取り出すと、それらはbase36値の順に検索されます。 AAAAAA、AAAAABなど。 - 文字列が取り出されると、それらもキャッシュから削除されるので、他のクライアントは同じ文字列を受け取ることはありません。順序付けられた永続キャッシュ
現在、永続キャッシュとしてMapDBを使用しています(EHCacheを使用しますが、永続ストレージのライセンスが必要です)。
MapDBは、私が要素を置く/取得できるマップを提供し、ディスクへの永続化を処理します。
私はそれが順序を提供し、私も削除/順序で要素を取得するためにpollFirstEntry
メソッドを呼び出すことができるので、JavaのConcurrentSkipListMap
クラスは、私の問題に役立つことに気づきました。
どのように私はMapDBでこれを使うことができるのか分かりません。誰かが私が概説した行動を達成する助けとなるアドバイスを持っていますか?
おかげ