MVC4 + EF + System.Threading.Thread 出现的问题记录

  项目要求是页面监测到后台数据库用户数据(Users)变化,前台做出相应的响应和操作。

 

一、参考很多资料,大概有几种方式:

参考资料地址:http://www.cnblogs.com/hoojo/p/longPolling_comet_jquery_iframe_ajax.html

客户端不停的向服务器发送请求以获取最新的数据信息。

轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接。
优点:后端程序编写比较容易。
缺点:请求中有大半是无用,浪费带宽和服务器资源。
实例:适于小型应用。


长轮询:客户端向服务器发送Ajax请求,服务器接到请求后hold住连接,直到有新消息才返回响应信息并关闭连接,客户端处理完响应信息后再向服务器发送新的请求。
优点:在无消息的情况下不会频繁的请求,耗费资源小。
缺点:服务器hold连接会消耗资源,返回数据顺序无保证,难于管理维护。
实例:WebQQ、Hi网页版、Facebook IM。

长连接:在页面里嵌入一个隐蔵iframe,将这个隐蔵iframe的src属性设为对一个长连接的请求或是采用xhr请求,服务器端就能源源不断地往客户端输入数据。
优点:消息即时到达,不发无用请求;管理起来也相对方便。
缺点:服务器维护一个长连接会增加开销。
实例:Gmail聊天


Flash Socket:在页面中内嵌入一个使用了Socket类的 Flash 程序JavaScript通过调用此Flash程序提供的Socket接口与服务器端的Socket接口进行通信,JavaScript在收到服务器端传送的信息后控制页面的显示。
优点:实现真正的即时通信,而不是伪即时。
缺点:客户端必须安装Flash插件;非HTTP协议,无法自动穿越防火墙。
实例:网络互动游戏。

其博文中最后提到基于html5WebSocket通信方式无奈楼主是新手,没有学习过,只能根据自己的理解来写代码。

 

二、代码

//login页面  2                                 var GetWeiXinLogin = function () {
 3                                     $.ajax({
 4                                         url: "/Member/GetWeiXinLogin.html",
 5                                         data: "Sceneid=@(Sceneid)",
 6                                         type: "get",
 7                                         success: function (data) {
 8                                             var dataObj = eval("(" + data + ")");
                            if (dataObj.reg == "success") {
15
alert('登录成功');16 } 17 } 18 }) 19 }

login页面 代码很简单,就是利用ajax无限访问后台的方法,该方法主要检测数据库数据变化。

 

 1  public void GetWeiXinLogin(int Sceneid)
 2         {
 3             string reg = "{\"reg\":\"408\"}";
 4             string Sql = " SELECT *  FROM WeiXinQRCodeTemporaryLog   WHERE (Sceneid = " + Sceneid + ") "; //查询语句
 5             for (int i = 0; i < 10; i++) //执行10次 总计20秒
 6             {
 7                 var WeiXinQRCodeTemporaryLogBySql = Entity.ExecuteStoreQuery<WeiXinQRCodeTemporaryLog>(Sql); //EF执行语句
 8                 int PUid = WeiXinQRCodeTemporaryLogBySql.FirstOrNew().Uid.GetValueOrDefault(); 
 9                 if (PUid != 0) //判断数据变化,如果==0 则前台得到相应
10                 {
11                     Users BaseUsers = Entity.Users.FirstOrNew(n => n.Uid == PUid);
12                     reg = "{\"reg\":\"success\",\"UTid\":\"" + BaseUsers.UTid + "\"}";
13 
14                     #region 登陆
15                     用户登录程序过程,省略...19                     #endregion
20                   26                     break;
27                 }
28                 System.Threading.Thread.CurrentThread.Join(2000); //没2秒执行一次
29             }
30             Response.Write(reg);
31             Response.End();
32         }

上面代码就是监测数据变化的简单程序,有高手应该看出问题了,代码的确是能实现想要的效果,但是你会发现,网站慢得让你奔溃!

比如我们访问login页面 的同时去访问我们同一个网站页面的Index.html页面,这个时候我们的Index.html页面加载非常得慢,一定会等到我们的异步加载完之后才能加载出我们的Index页面。

这只是个人开发过程中遇到问题的小小记录,勿喷哈,还请高手帮忙看看,初步估计问题就出在数据库访问和页面请求上。

posted on 2014-11-18 14:43  小小傅  阅读(228)  评论(0编辑  收藏  举报

导航