当前位置: 首页 > news >正文

网站代码结构苏州建设网站电话

网站代码结构,苏州建设网站电话,wordpress修改前缀,淘宝官网首页登录注册前言 因为项目需要把传感器的数据保存起来#xff0c;当时设计的时是mongo来存储#xff0c;后期需要从mongo DB里查询传感器的数据记录。由于传感器每秒都会像mongo数据库存500条左右的数据#xff0c;1天就有4320万条数据#xff0c;要想按照时间条件去查询#xff0c;…前言 因为项目需要把传感器的数据保存起来当时设计的时是mongo来存储后期需要从mongo DB里查询传感器的数据记录。由于传感器每秒都会像mongo数据库存500条左右的数据1天就有4320万条数据要想按照时间条件去查询经常会被卡死。以下是我的解决过程和方案。 解决方案 水平分表 按照传感器类型分表 将不同不同传感器的数据分别存入不同的表集合中这样每个表的数据就成倍减少但是过了一段时间发现查询嗨是很慢每个传感器每秒需要保存的数据也有100条左右一天就是864万条数据。仅靠类型分表是不行的。 按照日期分表 每个表每天的数据有864万条数据一个月就是2.6亿条数据。于是按照日期每天对每个传感器类型建设了一个表 表集合名格式如 ‘temperature_sensor_20240310’。 如保存数据时候自动创建分表代码如下 Asyncpublic T void insertSharding(Collection? extends T batchToSave, String collectionName) {String collectionNameSharding collectionName _ DateUtil.today();if (CollectionUtil.isNotEmpty(batchToSave)) {mongoTemplate.insert(batchToSave, collectionNameSharding);}}DateUtil.today() 是我工具类里的方法等效于 DateUtil.format(new Date(),“yyyyMMdd”)注意请保证每个传入的对象里都有一个createTime字段查询的时候会用到 按照时间查询分表的方法代码如下 public T ListT getSecondData(LocalDateTime start, LocalDateTime end, ClassT entityClass, String collectionName) {String collectionNameSharding collectionName_DateUtil.format(start,yyyyMMdd);// 设置时间范围查询条件Criteria criteria Criteria.where(createTime).gte(start).lte(end);// 查询数据return mongoTemplate.find(Query.query(criteria).limit(1000).skip(0), entityClass,collectionNameSharding);}代码中的 .limit(1000) 表示限制查询结果的数量即最多返回1000条匹配的文档记录。这对于分页查询或者批量处理数据时非常有用可以避免一次性加载过多数据导致内存溢出或响应延迟。 而 .skip(0) 则表示跳过前0条匹配的文档记录从第一条开始返回。在分页查询场景下如果你想获取第二页的数据通常会将skip的参数设置为每页大小假设也是1000即 .skip(1000)这样就会跳过前1000条然后取接下来的1000条数据。 经过以上操作查询数据的时候不会被卡顿了但是查询速度需要2s左右,项目需求查询速度至少得在200ms内所以还得继续优化。 建立索引 因为mongo水平分表的缘故不可能人工去对每个字段创建的表集合去建立时间索引需要代码实现创建表的同时自动创建时间索引。 修改分表数据保存方法如下 Asyncpublic T void insertSharding(Collection? extends T batchToSave, String collectionName) {String collectionNameSharding collectionName _ DateUtil.today();if (!mongoTemplate.collectionExists(collectionNameSharding)) {mongoTemplate.createCollection(collectionNameSharding);IndexOperations indexOps mongoTemplate.indexOps(collectionNameSharding);indexOps.ensureIndex(new Index().on(createTime, Sort.Direction.ASC).named(collectionNameSharding_createTime));}if (CollectionUtil.isNotEmpty(batchToSave)) {mongoTemplate.insert(batchToSave, collectionNameSharding);}}named(collectionNameSharding“_createTime”)) 即创建索引的名称on(“createTime”, Sort.Direction.ASC) 即使用集合中的createTime字段按照升序建立索引。 总结 经过以上水平分表和建立索引的方法按照时间条件去查询的方法已经可以优化到200ms左右了。本篇教程到此未知如果觉得不错记得一键三连感谢各位的支持
http://www.zqtcl.cn/news/665780/

相关文章:

  • 帮助企业做网站的销售卫浴洁具公司网站模板
  • 解释seo网站推广网站域名和空间费用
  • 深圳市珠宝网站建设手机网站框架
  • 晋城推广型网站开发dw做网站模板
  • 万网一个ip建立多个网站网页设计注册页面代码
  • 网站建设6000元地方门户网站有哪些
  • 十大SEO网站外链建设误区排版设计教程入门初学者
  • 网站基本维护网站设计软件下载
  • 网站开发的需求文档大型网站外链是怎么建设的
  • 网站建设实训心得与建议网站建设一般需要多少费用
  • 国内怎么打开WordPress网站wordpress制作api文件路径
  • 义乌网站开发公司wordpress段子模板
  • 国外有没有专门做靶材的网站做网站用哪个电脑
  • 郑州网站制作郑州网站制作上海网站建设免费推荐
  • php电子商务网站开发建设企业网站都需要啥
  • 从零学做网站如何让客户做网站
  • 关于销售网站建设的短文菜单宣传网站怎么做
  • 学网站开发有前途吗淮南服装网站建设费用
  • 网站外包附近临时工500元一天
  • 国外做logo的网站深圳有哪些软件外包公司
  • 网站加载流量一键生成app软件下载
  • 如何建设网站知乎襄阳做网站公司哪家好
  • 用ai怎么做网站专门做短视频的公司
  • 陶瓷类网站建设免费会员管理软件
  • 网站建设 用户管理一个服务器多个网站好吗
  • php做网站特效wordpress开启xmlrppc
  • 顺义重庆网站建设纪检监察网站建设
  • 网站制作源码企业品牌推广方式有哪些
  • 简述制作网站的流程网站开发后端用什么
  • 长沙好的网站建设公司厦门建网站多少钱