海量订单数据存储方法
首页->学习资料->编程语言->php教程->大型网站技术 关键词: 发布时间:2016-05-03 04:16:24 浏览次数:2000

首先,订单号防重复(时间戳+用户id),假设要存储淘宝这种级别的海量数据,首先根据情况规划好有多少台服务器(数据库),每个库又分成多少个表专门来存订单:

假设有16个库,每个库64个表,这样就有16*64=1024个订单表,每个表的存储压力就小了很多;


存储及查询路由,订单号最后两位数除以16取余数,可以确定存在哪个库,然后用订单号最后两位除以64除余数,确定存在对应库的哪个表中;


当然,这样也会存在其它无可回避的问题:

时间久了这些表也会变大,需要将相关数据迁移,成为历史表,这样做统计的时候就需要分别去查历史数据和新的数据;

赞:(0)
踩:(0)
相关文章
大型网站及面临的问题及解决方法
网页静态化
thinkphp网页静态化
sphinx全文索引
高并发时表锁与文件锁
高并发时商品库存处理方法
高并发测试及系统状态监测
PHP解决抢购、秒杀、抢楼、抽奖等
php多线程例子
php上传到七牛
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:933078
粤ICP备18028092号-1  微信:hurong241