
在高并发的情况下,
如何使用Mysql来统计一个页面的点击量?
希望能讲简单一点, 因为题主只会简单的sql语句, 不知道orm什么的;
其次, 如果用Mangodb这类nosql数据库实现, 又应该如何实现? 谢谢!
1 geeklian 2015-01-10 17:34:46 +08:00 高并发不应该把点击量扔到memcache或redis里么,然后隔一定时间,往mysql写一次。 |
2 lincanbin 2015-01-10 18:19:53 +08:00 via Android 往 Memcached 里存,每次自增1,当缓存里的统计值达到100000时,执行一次数据库update,然后缓存置零,一次一个update的话I/O吃不消 |
3 soulteary 2015-01-10 18:23:29 +08:00 如果你的内容数据量有限(万以内),不妨直接使用redis做存储,每次访问的时候,redis incr就好了。 |
4 jecvay OP @soulteary redis 不用考虑多人同时访问, 同时对这个键值 读取/写入 导致的错误问题吗? 就是说他自带锁一类的东西吗? |
5 RemRain 2015-01-10 19:10:51 +08:00 redis 是单线程的,不用加锁 |
7 soulteary 2015-01-10 19:17:25 +08:00 @jecvay redis没有锁,如果实在不放心,那么可以尝试使用发布订阅方式推阅读数量+1, 建议在安装完毕redis后,试一试```redis-benchmark ```,私以为,达不到读写的极限,妄谈锁...(使用速度跟不上的情况下,怎么触发写冲突呢) |
8 incompatible 2015-01-10 20:01:37 +08:00 @soulteary 冲突来自并发,与使用速度并无必然联系 比如一个web应用,平时可能没人用,但是突然某一时刻两个浏览器同时发请求过来,就会造成并发。redis的incr操作是原子性的,无需担忧并发的问题。 |
9 soulteary 2015-01-10 20:05:24 +08:00 @incompatible 谢指点。提到原子,不由想到原子锁...去翻下好了 |
10 poxzlm 2015-01-10 22:36:53 +08:00 via Android 你可以用redis实现一个简单的锁 是某一个set方法 就是若该schema不存在 则设置 若存在 则直接返回 因此你可以认为 设置成功表示进入锁 删除schema则表示释放锁。 |
11 cxclmm 2015-01-11 11:33:03 +08:00 楼主头像不错 |