场景:某网站需要对其项目做一个投票系统 , 投票项目上线后一小时之内预计有100万用户进行投票 , 希望用户投票完就能看到实时的投票情况
这个场景可以使用redis+MySQL冷热数据交换来解决 。
何为冷热数据交换?冷数据:之前使用的数据 , 热数据:当前使用的数据 。
交换:将Redis中的数据周期的存储到MySQL中
业务流程用户进行投票后 , 首先将投票数据保存到Redis中 , 这些数据就是热数据 , 然后定期(如5s)将热数据保存到MySQL中 , 这些数据就变为冷数据 , 然后将冷数据从Redis中删除 , 周而复始 , 知道一个小时投票结束 。
项目结构图
文章插图
index.html文件
这是投票的首页 , 有3个投票按钮 , 模拟给3个用户投票 , 点击按钮 , 使用ajax调用vote.php文件
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"><head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>Document</title></head><script src=https://www.isolves.com/it/cxkf/yy/php/2019-10-10/"http://lib.sinaApp.com/js/jquery/1.9.1/jquery-1.9.1.min.js">
0
0
0