硬件发送http post(get,put,delete)到aspx(ashx) 比如数据是这样的. { "deviceid","5", "tmp","28.5" } 那么我在http中可以解析然后执行 insert into table_data values("5","28.5",getdate()) 但是我现在要限制这个”客户端”的频率 比如 只能10s一次,否则我就输出{err:333,msg:次数太快} select top 1 date from table_data where deviceid="5" order by date desc 然后跟当前的datetime.now对比可以判断第二次请求跟第一次请求是否间隔了10s+ 这样的话还是频繁的访问了数据库..所以 能不能用一种别的方案来解决,免除数据库交互的过程? 现在想到的是 在web中(ashx或者aspx.cs) static dict<string,datetime> client 用于存放ip以及datetime.now. if 超时 输出{err:333,msg:次数太快} else 输出{err:0,msg:ok} client[ip]=datetime.now; 这样的话 多个客户端一起访问 应该没什么问题吧…. |
|
http://www.cnblogs.com/hb_cattle/articles/1852052.html
|
|
1分 |
如果你不存在负载均衡则没问题,不过用来保持访问时间的Dic可以考虑一下改用线程安全的Dic,叫ConxxxDic单词拼不全。。
|
110分 |
public static ConcurrentDictionary<string, DateTime> client = new ConcurrentDictionary<string, DateTime>(); var ip = Single.GetClientIP(); if (Single.client.ContainsKey(ip)) { var time = Single.client[ip]; var timestamp = (DateTime.Now - time).TotalSeconds; if (timestamp <= 10) { //code } Single.client[ip] = DateTime.Now; } else { Single.client.TryAdd(ip, DateTime.Now); } |