Esempio n. 1
0
        public ActionResult RunTest()
        {
            var sb = new StringBuilder();
            var containerCacheStragegy = CacheStrategyFactory.GetContainerCacheStragegyInstance();

            sb.AppendFormat("{0}:{1}<br />", "当前缓存策略", containerCacheStragegy.GetType().Name);


            for (int i = 0; i < 3; i++)
            {
                sb.AppendFormat("<br />====== {0}:{1} ======<br /><br />", "开始一轮测试", i + 1);
                var bagKey = DateTime.Now.Ticks.ToString();
                var bag    = new TestContainerBag1()
                {
                    Key      = bagKey,
                    DateTime = DateTime.Now
                };
                TestContainer1.Update(bagKey, bag);
                sb.AppendFormat("{0}:{1}(Ticks:{2})<br />", "bag.DateTime", bag.DateTime.ToLongTimeString(), bag.DateTime.Ticks);

                Thread.Sleep(1);

                bag.DateTime = DateTime.Now;//进行修改

                //读取列队
                var mq     = new SenparcMessageQueue();
                var mqKey  = SenparcMessageQueue.GenerateKey("ContainerBag", bag.GetType(), bag.Key, "UpdateContainerBag");
                var mqItem = mq.GetItem(mqKey);
                sb.AppendFormat("{0}:{1}(Ticks:{2})<br />", "bag.DateTime", bag.DateTime.ToLongTimeString(), bag.DateTime.Ticks);
                sb.AppendFormat("{0}:{1}<br />", "已经加入列队", mqItem != null);
                sb.AppendFormat("{0}:{1}<br />", "当前消息列队数量(未更新缓存)", mq.GetCount());

                var cacheKey       = TestContainer1.GetCacheKey();
                var itemCollection = containerCacheStragegy.Get(cacheKey);
                sb.AppendFormat("{0}:{1}<br />", "当前缓存是否存在", itemCollection.CheckExisted(bagKey));
                sb.AppendFormat("{0}:{1}<br />", "插入缓存时间", itemCollection[bagKey].CacheTime.Ticks);//应为0

                var waitSeconds = i;
                sb.AppendFormat("{0}:{1}<br />", "操作", "等待" + waitSeconds + "秒");
                Thread.Sleep(waitSeconds * 1000);//线程默认轮询等待时间为2秒
                sb.AppendFormat("{0}:{1}<br />", "当前消息列队数量(未更新缓存)", mq.GetCount());

                itemCollection = containerCacheStragegy.Get(cacheKey);
                sb.AppendFormat("{0}:{1}<br />", "当前缓存是否存在", itemCollection.CheckExisted(bagKey));
                sb.AppendFormat("{0}:{1}(Ticks:{2})<br />", "插入缓存时间", itemCollection[bagKey].CacheTime.ToLongTimeString(), itemCollection[bagKey].CacheTime.Ticks);//应为当前加入到缓存的最新时间
            }

            return(Content(sb.ToString()));
            //ViewData["Result"] = sb.ToString();
            //return View();
        }
Esempio n. 2
0
        public ActionResult Redis(int id = 1)
        {
            //测试Redis ItemCollection缓存更新功能

            if (id == 1)
            {
                CacheStrategyFactory.RegisterContainerCacheStrategy(() => RedisContainerCacheStrategy.Instance);
            }
            else
            {
                CacheStrategyFactory.RegisterContainerCacheStrategy(() => null);
            }

            var sb       = new StringBuilder();
            var cacheKey = TestContainer1.GetCacheKey();
            var containerCacheStragegy = CacheStrategyFactory.GetContainerCacheStragegyInstance();
            var itemCollection         = containerCacheStragegy.Get(cacheKey);

            sb.AppendFormat("Count1:{0}<br />", itemCollection != null ? itemCollection.GetCount() : -1);


            var bagKey = "Redis." + DateTime.Now.ToString();
            var bag    = new TestContainerBag1()
            {
                Key      = bagKey,
                DateTime = DateTime.Now
            };

            TestContainer1.Update(bagKey, bag);//更新到缓存(列队)

            itemCollection = containerCacheStragegy.Get(cacheKey);

            sb.AppendFormat("Count2:{0}<br />", itemCollection != null ? itemCollection.GetCount() : -1);

            if (itemCollection != null)
            {
                itemCollection[DateTime.Now.Ticks.ToString()] = bag;
            }

            sb.AppendFormat("Count3:{0}<br />", itemCollection != null ? itemCollection.GetCount() : -1);

            return(Content(sb.ToString()));
        }