mysql 冷热表_Redis+MySQL冷热数据交换

场景:某网站需要对其项目做一个投票系统,投票项目上线后一小时之内预计有100万用户进行投票,希望用户投票完就能看到实时的投票情况

这个场景可以使用redis+mysql冷热数据交换来解决。

何为冷热数据交换?

冷数据:之前使用的数据,热数据:当前使用的数据。

交换:将Redis中的数据周期的存储到MySQL中

业务流程

用户进行投票后,首先将投票数据保存到Redis中,这些数据就是热数据,然后定期(如5s)将热数据保存到MySQL中,这些数据就变为冷数据,然后将冷数据从Redis中删除,周而复始,知道一个小时投票结束。

项目结构图

117060156_1_20171123031357534

index.html文件

这是投票的首页,有3个投票按钮,模拟给3个用户投票,点击按钮,使用ajax调用vote.php文件

Document

0

0

0

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

vote.php

这个文件主要实现投票的逻辑。首先连接上Redis服务器,然后保存投票人id,然后将投票人id为key记录每个用户的票数,然后返回给index.html文件,最后使用global_voteid作为key记录总票数,也可以作为MySQL的自增长的键。然后记录uid,ip,time等数据。

注意格式有一定的要求:

假如voteid为3,记录的是ip,那么键为vote:3:ip:127.0.0.1<?php $redis = new Redis();$redis->connect('localhost',6379);//计算每个用户的总票数$uid = intval($_GET['uid']);//$uid = mt_rand(1,3);//随机指定投票人员,方便进行压力测试echo $redis->incr($uid);$voteid = $redis->incr('global_voteid');$redis->set('vote:'.$voteid.':uid',$uid);$ip = $_SERVER['REMOTE_ADDR'];$redis->set('vote:'.$voteid.':ip',$ip);$redis->set('vote:'.$voteid.':time',time());1

2

3

4

5

6

7

8

9

10

11

12

13

重点内容

这个文件主要实现冷热数据交换,首先连接MySQL数据库和redis服务器,然后每隔5秒去执行while循环,在while循环里获取自增长的投票主键和最近一次插入mysql的投票主键(位置)。判断插入的位置是否存在,如果不存在就从头插入,如果全部插入完毕,就进行等待,如果没有插入完毕,就进行插入操作。<?php //连接数据库$pdo = new PDO('mysql:host=localhost;dbname=test','root','1234');$pdo->query('set names utf8');//连接redis$redis = new Redis();$redis->connect('localhost',6379);//永真循环while(true){ $vid = $redis->get('global_voteid');//自增长的主键 $last = $redis->get('last');//最近一次插入mysql的投票主键 //如果没有插入数据库,刚开始的肯定为true if(!$last){ $last = 0;//设置为0 } //如果所有的数据都被插入到MySQL中 if($vid == $last){ echo "wait\n";//输出等待 }else{ //进行插入到数据库操作 $sql = 'insert into vote(vid,uid,ip,time) values'; for($i = $vid;$i>$last;$i--){ $k1 = 'vote:'.$i.':uid'; $k2 = 'vote:'.$i.':ip'; $k3 = 'vote:'.$i.':time'; $row = $redis->mget([$k1,$k2,$k3]); $sql.="($i,$row[0],'$row[1]',$row[2]),"; $redis->delete($k1,$k2,$k3); } $sql = substr($sql,0,-1); $pdo->exec($sql); $redis->set('last',$vid);//设置插入的主键位置 echo 'OK'; } sleep(5);//每隔5秒执行循环}1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

vote表

117060156_2_20171123031357877

运行步骤:

1、使用php命令行工具调用swap.php

117060156_3_20171123031357955

2、使用Apache的ab工具进行压力测试。

117060156_4_20171123031358580

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/246414.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于包装java_[java初探09]__关于java的包装类

前言在Java语言的学习过程中,我们逐渐的理解了Java面向对象的思想,与类和对象的应用.但是在基本数据类型的使用上,我们无法将其定义为一个对象,通过使用对象的方法来使用它们,但是Java语言的思想又是面向对象的.那么在Java语言中,是否能够解决这个问题,使基本数据类型能够以对象…

能跑java的服务器_一台java服务器可以跑多少个线程?

一台java服务器能跑多少个线程&#xff1f;这个问题来自一次线上报警如下图&#xff0c;超过了我们的配置阈值。京东自研UMP监控分析打出jstack文件&#xff0c;通过IBM Thread and Monitor Dump Analyzer for Java工具查看如下&#xff1a;IBM Thread and Monitor Dump Analyz…

希尔排序基础java代码_java 算法之希尔排序详解及实现代码

摘要&#xff1a;这篇Java开发技术栏目下的“java 算法之希尔排序详解及实现代码”&#xff0c;介绍的技术点是“希尔排序详解、实现代码、希尔排序、Java、实现、代码”&#xff0c;希望对大家开发技术学习和问题解决有帮助。java 算法之希尔排序一、思想希尔排序&#xff1a;…

java设置属性的取值范围是多少_jvm-Java系统属性的范围

系统属性的范围至少从阅读Properties方法的API规范后&#xff0c;我无法获得关于是否由JVM的所有实例共享系统属性的答案。为了找出答案&#xff0c;我编写了两个快速程序&#xff0c;这些程序将使用相同的键但不同的值通过Properties设置系统属性&#xff1a;class T1 {public…

centos卸载内核_CentOS 中内核模块的加载和卸载

Linux操作系统的核心具有模块化的特性&#xff0c;在编译核心时&#xff0c;我们可以将系统功能编译成一个个单独的模块&#xff0c;待需要时再分别载入。lsmodlsmod命令用于显示已经加载到内核中的模块的状态信息。执行lsmod命令后会列出所有已载入系统的模块。insmodinsmod命…

java如何使用配置文件_如何使用java.util.Properties读取配置文件?

当我们有一个使用文本文件存储配置的应用程序且该配置通常为keyvalue格式时&#xff0c;我们可以java.util.Properties用来读取该配置文件。这是一个名为的配置文件示例app.config&#xff1a;app.nameProperties Sample Codeapp.version1.0下面的代码向您展示了如何读取配置。…

php取json子对象属性,php中输出json对象的值(实现方法)

实例如下所示&#xff1a;$json {"report":{"date":"2012-04-10","content":"abcdefght"}};$arr (array) json_decode($json,true);echo 当前日期是&#xff1a;. $arr[report][date];echo "";echo ;print_r($a…

zend optimizer php5.5,PHP_PHP5.3以上版本安装ZendOptimizer扩展,现在很多PHP程序都需要ZendOptimi - phpStudy...

PHP5.3以上版本安装ZendOptimizer扩展现在很多PHP程序都需要ZendOptimizer环境&#xff0c;但是ZendOptimizer在PHP5.2之后已经被支持&#xff0c;那怎么办&#xff0c;Zend也不会这么做&#xff0c;原来PHP5.3开始ZendOptimizer正式改为Zend Guard Loader。Zend Guard Loader的…

php导出excel出现乱码,php导出数据到excel出现乱码的解决办法

代码如下&#xff1a; 代码示例:/*** 导出数据到excel 解决乱码问题* Edit www.#*/function xlsBOF() {echo pack("ssssss", 0x809, 0x8, 0x0, 0x10, 0x0, 0x0);return;}function xlsEOF() {echo pack("ss", 0x0A, 0x00);return;}function xlsWriteNumber(…

php mysql 表关联,mysql的多表关联_MySQL

bitsCN.commysql的多表关联数据库中经常要用到多个表的关联。mysql的关联主要包括inner join&#xff0c;left join&#xff0c;right join三种&#xff0c;下面分别加以介绍&#xff0c;并举例说明。顾名思义&#xff0c;inner join集合了两个表的信息&#xff0c;只有都包含的…

ulink php,【转载】15款USB数字界面横向评测(对比顶级CD转盘)!多看点!

还有一则有趣的回帖&#xff0c;一位纽约的烧友认为作者没有尝试何庆华最新的数字界面非常可惜&#xff0c;他认为何先生自主开发的DI-V3电源套件非常之牛&#xff0c;甚至超过了AP1PP的水准(不少人认为这个组合有一点点过于分析&#xff0c;不如何先生的作品水润)。他认为以他…

php取掉字符串第一位支付,php怎样去掉字符串中的第一个字符

php去掉字符串中的第一个字符的方法&#xff1a;可以利用substr()函数来实现。substr()函数可以返回字符串的提取部分&#xff0c;如果失败则返回false&#xff0c;或者返回一个空字符串。substr() 函数返回字符串的提取部分&#xff0c;如果失败则返回 FALSE&#xff0c;或者返…

php自动运维,运维自动化之使用PHP+MYSQL+SHELL打造私有监控系统(五)

include("conn.php");include("head.php");include("province.php");?>应用服务编号省份被监控服务器IP监控服务器监控服务当前状态监控时间$SQL"SELECT * FROM gansu_service order by date desc limit 0,13";$querymysql_query(…

matlab lpfilter.m,histroi/statmoments/lpfilter/dftuv的Matlab程序

(摘自冈萨雷斯的《数字图像处理(使用Matlab)》)&#xff1a;l function [P,npix]histroi(f,c,r)% HISTROI Computes the histogram of an ROIin an image.% [P,npix]histroi(f,c,r) computes thehistogram,P,of a% polygonal region of interest (ROI) inimage F.The polygonal…

matlab求距离判别函数,求MATLAB的逐步判别程序 - 仿真模拟 - 小木虫 - 学术 科研 互动社区...

somomo91你不觉得信息量太少了么&#xff1f;摸不着头脑&#xff0c;zhouxiaobo是啊&#xff0c;信息量太少&#xff0c;LZ能详细描述一下你的问题吗或者直接给出你的数据和要求2012jxyl引用回帖:zhouxiaobo at 2013-06-06 09:44:49是啊&#xff0c;信息量太少&#xff0c;LZ能…

php验证码背景图是数字,ThinkPHP5.0.20验证码背景图片

tp5配置验证码相关问题一、验证码背景图片及tp中文验证码5.0.1及以上支持者在应用配置目录(application)下面 extra 子目录内配置captcha.php文件&#xff1b;配置参数如下&#xff1a;2345678abcdefhijkmnpqrstuvwxyzABCDEFGHJKLMNPQRTUVWXY,// 验证码字体大小(px)fontSize &g…

php mongo 游标超时,游标在MongoDb游标上超时错误

我刚开始使用mongoDb作为PHP的后端.我只是使用find()查询来满足我的一个需求.我只想要前100个结果,但也想获得总体可用结果.我正在尝试这个.$cursor $this->dbReference->dbName->find($query);if($count ! 0){$cursor->skip($startIndex);$cursor->limit($cou…

matlab二项式拟合,数据回归分析和拟合的Matlab实现

复制代码多元二项式回归1.1、多元二项式回归Matlab命令rstool(x,y,model,alpha)输入参数说明&#xff1a;x&#xff1a;n*m矩阵&#xff1b;Y&#xff1a;n维列向量&#xff1b;alpha&#xff1a;显著性水平(缺省时为0.05)&#xff1b;mode&#xff1a;由下列4个模型中选择1个(…

c mysql安装教程,Mysql安装教程_完成版(吐血式安装)

每次在不同操作系统中安装oracle和mysql这些常规数据库&#xff0c;步骤就那么点儿&#xff0c;但是遇见的错误却是千差万别。。记一次耗时两天的mysql数据库安装新得&#xff0c;有耐心&#xff0c;有毅力&#xff0c;憋生气。1.官网上下载免安装的版本(也就是下载下来直接解压…

查询oracle表上重复的数据库,如何确定Oracle数据库表重复的记录

正在看的ORACLE教程是:如何确定Oracle数据库表重复的记录。 作为一个Oracle数据库开发者或者DBA&#xff0c;在实际工作中经常会遇到这样的问题&#xff1a;试图对库表中的某一列或几列创建唯一索引时&#xff0c;系统提示ORA-01452&#xff1a;不能创建唯一索引&#xff0c;发…