先来说明一下问题,2楼开始说解决方案
委托delegate与Dictionary实现action选择器大家先看看我上一次的文章
大致如下
[C#] 纯文本查看 复制代码 //定义一个委托
private delegate void actionByMain(HttpContext context);
//定义一Key,Value的键值对,大家注意这里把委托放进去了
private static Dictionary<string, actionByMain> mainList = new Dictionary<string, actionByMain>();
public void ProcessRequest(HttpContext context)
{
string action = string.Empty;
if (string.IsNullOrEmpty(context.Request["action"]))
{
return;
}
action = context.Request["action"];
//先检查一下有没有这个action
if (mainList.ContainsKey(action))
{
mainList[action](context); return;
}
}
//添加action对应方法的列表
static void addMainList()
{
mainList.Add("post1", delegate(HttpContext context)
{
context.Response.Write("成功");
});
mainList.Add("post2", delegate(HttpContext context)
{
context.Response.Write("成功");
});
mainList.Add("post3", delegate(HttpContext context)
{
return;
});
}
就是这样的写法,容易出现问题
在高并发的时候经常出现页面无法访问的问题
其实我也不敢确定是不是这里的问题但是有以下几点可以确定
可能会有人说,如果不使用这种而是直接调用静态方法呢,是一样的效果。这点我测试过。
第一点换成普通类型
换成如下写法就不会出现这样的问题
[C#] 纯文本查看 复制代码 //取出action的值
string action = context.Request["action"];
if (action == "post1")
{
//调用第一个Post方法
}
else if (action == "post2")
{
//调用第一个Post方法
}
else if (action == "post3")
{
//调用第一个Post方法
}
else
{
//调用在没有找到action对应方法时执行
}[/code]
方法如下
[mw_shl_code=csharp,true] private void post1()
{
}
private void post2()
{
}
private void post3()
{
}
第二点:访问量比较小时,本页面日访问量低于2万Pv的就不要测试了,应该不会有效果
这个我经过测试确定是这样的
第三点:IIS设置应用程序池不回收时,也不会出现这样的问题,但是只要设置回收就会出现
这一点虽然我不知道是什么情况但是实际效果就是这样
总结:
这个问题一直得不到一个完整合理的解释,希望博客园的高手们进来看看,帮助解释一下是什么问题造成的。
我的理解:
我认为会不会是因为正好在高并发的时候IIS开始回收,在回收时或者是在页面重建时,就在这一刻是无法访问的,而且正好让用户访问了,而这个状态正好被浏览器记录了下来,然后就不能访问了,
第四点:因为经过我们的测试,只要清理一下浏览器的缓存或者是重启电脑路由之后就基本上又可以正常访问了。
这种现像很难解释啊,
所以没有办法后来我又修改成了。普通的写法。
大家讨论一下看看具体是那里的问题
我确实是解释不了这种现像了。
|