最近了解了一下LevelDB,發覺這個嵌入式的K-V數據性能不錯,因此順便想在使用層面瞭解一下.因爲LevelDB也有針對.net的實現,因此就針對了LevelDB.NET進行了一個簡單的讀寫壓力測試.爲了更客觀的體現測試結構因此添加了大量的數據,和GET操做的時候隨機已經有的KEY進行. git
public static void WriteTest(object state) { while (true) { User user = new User(); string id = GetKey().ToString("000000000000000000000"); user.Name = id; user.EMail = id + "@msn.com"; user.CrateTime = DateTime.Now; user.City = "GZ" + id; user.Country = "CN" + id; user.Address = "sdfffffffffffffffffffffffffafjsdfjsljfsjfls"+id; user.Phone = id; user.Region = "gd"; db.Set(user.Name, user); System.Threading.Interlocked.Increment(ref mCount); } }
while (true) { User user; int index = ran.Next(100000, 500000); if (index == li) { Console.WriteLine(index); } li = index; user = db.Get<User>(index.ToString("000000000000000000000")); System.Threading.Interlocked.Increment(ref mIndex); System.Threading.Interlocked.Increment(ref mCount); }
LevenDB.Net的寫入速度很是高效,在單線程寫入的狀況均可以達到接近5W/秒的效率,而在獲取上的效率更高5線程的併發讀居然能夠達到15W/秒的能力....這讀效果是至關的可觀. github
我的站:www.ikende.com 併發
我的開源項目github.com/IKende 性能