Memocache

http://blog.csdn.net/zhoufoxcn/article/details/6282099

http://blog.csdn.net/dinglang_2009/article/details/6917794

public void TestMemcache()
{
var list = new List<MktPriceMarketData>();
var Dao = (Framework.IService.ICommonService)ctx["CommonService"];
var list1 = Dao.ExecuteRowMapper(new Framework.QueryInfo() { CustomSQL = "select * from mkt_price_market_data" }, new MktPriceMarketData()).ToList();
for (int i = 0; i < 3; i++)
{
list1.AddRange(list1);
}
MemcachedClient client = new MemcachedClient();
//初始化服务器和端口
string[] servers = { "127.0.0.1:11211" };
//初始化连接池
SockIOPool pool = SockIOPool.GetInstance();
pool.SetServers(servers);
pool.InitConnections = 3;
pool.MinConnections = 3;
pool.MaxConnections = 5;
pool.SocketConnectTimeout = 1000;
pool.SocketTimeout = 3000;
pool.MaintenanceSleep = 30;
//故障转移
pool.Failover = true;
pool.Nagle = false;
pool.Initialize();
//客户端实例
MemcachedClient mc = new MemcachedClient();
mc.EnableCompression = false;
mc.Add("kxb", "柯相彬");
mc.Add("kxq", "my name is kxq");
int pageSize = 1000;
int total = list1.Count;
int pages = ((total - 1) / pageSize) + 1;
Parallel.For(1, 100, i =>
{
var objList = list1.Skip((i - 1) * pageSize).Take(pageSize).ToList();
string key = "m" + i;
mc.Delete(key);
mc.Add(key, objList);
});

var list3 = new ConcurrentBag<MktPriceMarketData>();

Parallel.For(1, 100, i =>
{
string key = "m" + i;
var kuai = (List<MktPriceMarketData>)mc.Get(key);
Parallel.ForEach(kuai, item =>
{
list3.Add(item);
});
});
}

 

posted on 2018-01-07 16:21  听哥哥的话  阅读(159)  评论(0编辑  收藏  举报

导航