数据库问题求指教!

2015-01-10 17:17:45 +08:00
 jecvay

在高并发的情况下,
如何使用Mysql来统计一个页面的点击量?

希望能讲简单一点, 因为题主只会简单的sql语句, 不知道orm什么的;

其次, 如果用Mangodb这类nosql数据库实现, 又应该如何实现? 谢谢!

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

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/160916

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX