本文摘自PHP中文网,作者齐天大圣,侵删。
首先看应用场景:几年前,微信里许多投票系统。很多人都找好友或朋友圈找人拉票。当时,有一个比较大的乐园也做了这个投票活动,好像是超过一定票数就可以免费玩。我也被好友要求给他投票,一天好像可以投3票还是5票,具体的记不太清了。我当时进去该系统后,给朋友点了投票按钮,发现没有任何反应。我以为是我网络的问题,后来发现是程序的问题。我当时猜测,它应该是投票的人太多了,系统一时没抗住。因为当时,我刚好在学redis。所以,我想可以通过redis的计数器来改善该功能。
这里,我们只统计用户总的投票数,而不考虑用户具体的投票情况,像A什么时候给B投票的记录我们不做考虑。这种情况如果考虑的话,就要使用其他的解决方案了(可以用消息队列)。
校验
首先,要对每个用户的投票数进行校验。用户每天都有3次投票机会,所以,我们可建立个键,将他的有效期设为明天凌晨。用户每投一票就加1等到了3票后,就提示今日次数已用完。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
统计投票
次数校验通过后,就需要统计用户的得票数了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
我自己的阿里云主机配置只有1核cpu1G内存的配置,每秒incr性能能达到10万多次,redis性能真恐怖。
1 2 |
|
Mysql异步更新用户得票数
相关阅读 >>
更多相关阅读请进入《Redis》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。