正常情况下是没有问题的,
但是有人用恶意脚本进行刷奖,也就是同一个人发起大量请求,1秒可能一两百的请求甚至更多,而且不只一个人刷奖。
问题出在1这一步
举个例子,假设每人只能抽一次奖,因为请求太快,同一人的a,b两个请求几乎同时来,a走完抽奖逻辑了,并且在抽奖表中插入记录的过程时,因为mysql的性能的问题,b去走1这一步是读不到表中的记录的,因为a的插入根本没有完成。所以b请求会再走一次抽奖逻辑。造成同一人抽奖两次,然后再插入抽奖表。
我关心的是能否a插入抽奖表的瞬间,b就能判断出抽奖表有数据。
所以我觉得问题是mysql写入的不够快,读取的不够快,所以我要采用redis做一层快速缓存。
我们做的抽奖是单一奖品百分之百中奖,只限制奖品数量,所以必须保证每人只能抽一次,而且尽量在程序层面去解决。
然后你需要安装Composer,确保composer在你的环境变量下,在命令行里面输入composer about验证一下安装完成后cd到lumen-api-starter文件夹下,复制.env.example重命名为.env进行设置,APP_KEY必须是32位的
1) mysql_result($result,0,0)返回你要取的结果集从第一行开始的第1列的值,就是结果集中第一行ID字段的值为18.2) mysql_result($result,5)返回错误,是因为你的结果集只有5条记录,参数5表示第6条记录(行号从0开始)3)mysql_result($result,0,‘choice’)返回错误,是因为你的数据表没有choice这个字段。
先明白你要做什么,需要使用什么技术,这个事就简单了许多。
首先是视频源,怎么样把视频统一转换成flv,(可以使用服务来处理,有很多软件做成服务后,会自动转换视频格式。) 第二,插入器,可以使用开源的flv播放器,也可以自己开发一个。第三,php+mysql这一部分,完全不用自己写,现然开源的cms很多,支持视频模型的也有。可以直接使用。你要做的工作,就是美化一下视频播放页面,把用户传上来的视频转成flv再放回数据库。需要查看php的mysql扩展模块有没有开启,以及支持的mysql客户端版本,再有mysql的服务端有没有正常开启。
以上就是关于php mysql 教程以及怎么异步redis同步到mysql数据库的相关回答,有更多疑问可以加微。Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有