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

郑州做网站公司seo网站内部优化

郑州做网站公司,seo网站内部优化,利用php做直播网站,vs简易新闻建设网站简单的场景: 全量数据更新的情况下, 不在乎同一秒的请求都必须要成功, 只留下最新的更新请求数据 方案常用的是 1、数据库增加时间戳标识实现的乐观锁, 请求参数从源头带上微秒或者毫秒时间戳数据库存储, 然后在更新SQL语句上比较 (数据库的时间 参数传递的时间) 例如: A…简单的场景: 全量数据更新的情况下, 不在乎同一秒的请求都必须要成功, 只留下最新的更新请求数据 方案常用的是 1、数据库增加时间戳标识实现的乐观锁, 请求参数从源头带上微秒或者毫秒时间戳数据库存储, 然后在更新SQL语句上比较 (数据库的时间 参数传递的时间) 例如: ALTER TABLE mytable ADD accessTime DATETIME(6) DEFAULT CURRENT_TIMESTAMP(6) not null comment ‘请求源头时间(精度高),用于更新比较,解决并发修改’; UPDATE mytable SET updateTime ?, accessTime? WHERE statusId ? AND (IFNULL(accessTime, DATE_SUB(NOW(), INTERVAL 2 MINUTE)) ?); 复杂场景: 比如, 更新数据时候不是全量数据更新的方式, 可能是增量更新或者是覆盖部分更新; 场景: 比如MongoDB数据库, 文档中的某个object字段下有很多key:value, [图片] 一种并发情况: 并发A、B请求的时候, 他们的请求参数分别新增加不同的object字段下的Key, 或者是覆盖key, 这种新增Key的情况下需要并发的A、B请求都要成功, {properties.label:24.700000} {properties.thermostat.localTemp:24.800000} 另外一种情况: 并发A、B请求的时候, 他们的请求参数分别相同的object字段下的Key, 这种情况下需要并发的A、B请求只要最新请求能成功, 比如是A是先请求, B后请求, 那么就不能存在数据库最终存储的数据是A的; {properties.thermostat.localTemp:24.700000} {properties.thermostat.localTemp:24.800000} 方案 基于时间戳的乐观锁方式 判断keys的hash算法, 具体如下 请求参数源码增加一个时间戳, 透传到数据库存储; 根据请求测试里面的所有的keys , 按规则排序, 后进行hash算法计算出值, 然后插入到表里面; 后面更新判断hash算法是否一致, 不一致则判断为增量更新, 不用判断时间戳让其更新成功; 如果hash算法一致则判定为一致, 需要判断数据库时间戳 传递的时间戳; 并且这个判断不能在程序中实现, 比如先查询出来然后再比较, 后更新, 这种方式不是原子性的; 但是这种方法还是存在缺陷, 比如: A线程先请求 参数是: b2 {“fanMode”: “auto1”, “speedPercent”: 0} A 由于hash不同也能更新成功, 最终b2, 但是由于是B后请求是, 其实最终数据要b1 B线程后请求 参数是: b1 {“fanMode”: “auto2”} B先执行成功; 上面方法主要是解决相邻的2个间隔短的相同key参数请求伪代码: // 并发控制, 组装请求参数的TreeSet排序的keys-1 Set propertiesKeys new TreeSet(); for (Map.EntryString, Object entry : properties.entrySet()) { if (entry.getValue() null) { continue; } // 并发控制, 组装请求参数的keys-2 propertiesKeys.add(entry.getKey()); recursiveCalculationAddKeys(entry.getValue(), propertiesKeys); } // 并发控制, 获取keys_Md5-3 String string propertiesKeys.toString(); String md5DigestAsHex DigestUtils.md5DigestAsHex(string.getBytes(StandardCharsets.UTF_8)); deviceStatus.setPropertiesKeysMd5(md5DigestAsHex); request.setCompareAccessTime(Boolean.TRUE); public static void recursiveCalculationAddKeys(Object value, Set propertiesKeys) { if (Objects.isNull(value)){ return; } String type value.getClass().getSimpleName(); if (value instanceof Map || type.endsWith(“HashMap”)) { MapString, Object valueMap (MapString, Object) value; valueMap.forEach((k, v) - { propertiesKeys.add(k); // 递归处理所有是map的值 recursiveCalculationAddKeys(v, propertiesKeys); }); } // 处理是List的情况 if (value instanceof List || type.endsWith(ArrayList)){ListObject valueList (ListObject) value;valueList.forEach(el-{// 递归处理所有是map的值recursiveCalculationAddKeys(el, propertiesKeys);}); }} Criteria criteriaVar2 Criteria.where(“statusId”).is(oldDs.getStatusId()); Query queryVar2 new Query(criteriaVar2); if (compareAccessTime) { // md5比较存在情况下增加查询条件走单更新方法 criteriaVar2.orOperator( Criteria.where(“propertiesKeysMd5”).is(propertiesKeysMd5).and(“accessTime”).lt(accessTime), Criteria.where(“accessTime”).is(null), Criteria.where(“propertiesKeysMd5”).is(null), Criteria.where(“propertiesKeysMd5”).ne(propertiesKeysMd5) ); // 匹配空值 queryVar2 new Query(criteriaVar2); } mongoTemplate.findAndModify(queryVar2, update, Map.class, “…”) 1
http://www.hkea.cn/news/14401950/

相关文章:

  • 网站推广如何指定关键词优化网站开发是哪个职位
  • 南京江宁网站制作买域名在哪里买
  • 网站怎做百度代码统计室内设计效果图图片
  • 做装修哪个网站推广好求个免费网站好人有好报
  • 手机版网站打开速度慢吉安信息网
  • 怎么做百度联盟网站网站分辨率做96是否会更好
  • 在国际网站上做贸易怎么发货西安赶集网官网
  • 在门户网站做推广wordpress 改ip
  • 满洲里网站制作免费网站下载大全
  • 瑞安市住房和城乡规划建设局网站网站开发毕设答辩
  • 如何免费建一个学校网站微网站建设步骤
  • 上海有名的做网站的公司有哪些wordpress去掉顶部工具栏
  • 网站制作添加视频网站模板asp
  • 狼们求个没封的免费网站网店美工培训
  • 小说网站分页关键字怎么做如何制作一个微信公众号
  • 专业零基础网站建设教学在哪里西安网站建设公司排
  • 手机网站建设图开源企业cms建站系统
  • 网站搭建环境wordpress 安卓主题下载
  • 建设网站需要分析什么海报模板素材网站
  • 海络网站烟台网站制作设计
  • 网站实现搜索功能三明市建设局网站
  • 数据库网站计算机网站建设好不好
  • 济南网站建设是什么意思wordpress 广告代码
  • ftp怎么做网站狼雨的网站
  • 网站升级改版wap手机网站 作用
  • 网页设计网站搭建网络运营商无服务怎么办
  • 示范校建设专题网站网站统计帮哪个好
  • 购物网站建设目标客户分析论文深圳市建设工程交易
  • 网站地图可以自己做么网站免费建站性盈盈影院
  • 博物馆建设网站的作用湛江seo