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

做啥网站最挣钱最近三天的国际新闻大事

做啥网站最挣钱,最近三天的国际新闻大事,凡科 wordpress,软件测试培训班开发的MES,往往都要做生产执行跟踪扫描,这样会产生大量的扫描数据,用关系型数据库,很容易造成查询冲突的问题。 生产跟踪扫描就发生的密度是非常高的,每个零部件的加工过程,都要被记录下来,特别…

        开发的MES,往往都要做生产执行跟踪扫描,这样会产生大量的扫描数据,用关系型数据库,很容易造成查询冲突的问题。

        生产跟踪扫描就发生的密度是非常高的,每个零部件的加工过程,都要被记录下来,特别是在大型工厂。写入密度高,但是每次写入的记录都很少,如果程序设计是实时往数据库写入记录,那基本是每次一条记录,且写入的频率很高,导致表锁时常发生,对查询扫描日志会带来很大的压力。

        解决跟踪扫描的问题,最好的办法还是用缓存(Redis),而且要共享缓存,就是不同用户使用同一个缓存空间,防止相同的零部件扫描时候,不会出现相互冲突。实际生产过程中,扫描冲突是不应该发生的,但是偏偏就是会发生,例如操作员后补扫描。程序发起扫描请求时候,先去查询缓存是否存在扫描记录,如果有,则根据缓存中的数据进行扫描校验,例如是否存在扫描的编号、重复扫描、扫描次数限制等;如果缓存中没有数据,则表明零部件从来没有被扫描过,则从数据库中加载基础信息,例如零部件的信息、工序的信息、工作中心的信息等,然后这些信息也放到缓存中,基础信息不能存放太久,一般扫描也就毫秒级完成,算1秒吧,可以设置缓存超时清除,我这里是设置10分钟的绝对超时,10分钟后重新从数据库加载基础数据。

        扫描数据一直保存在缓存中,根据生产周期,也可以设定一个延期超时,例如90天,每访问一次,就重置超时时间。扫描记录,可以全部存放到内存缓存中(MemoryCache),用一个定时器往数据库中写入扫描记录,不管扫描是否成功,日志都要写入数据库保存。如果出现数据库事务冲突或者超时,则后续继续往数据库中写入,直到写入成功后,才从内存缓存中移除扫描数据。

        一般来说,程序设计查询扫描记录,从缓存中查询即可,数据结构采用Hash保存:

        Key:                Scan_零部件编号,注意,部件编号这里是全局唯一

        HashKey        工序编号

        Value                扫描数据json        [ {'scanTime':'2024-01-01','operator':'001'}]

        因为同一个工序,可能需要扫描2次或者以上的,所以value的设计是个集合

当查询的时候,只需要把key的所有数据一次性读取出来丢去前端即可,完全不需要查询数据库。不管是写入还是读取,都比数据库快很多,代码也很简洁。当然,之类最好把操作缓存的功能封装成一个工具类,毕竟设计到内存缓存和Redis。

        在常规的需求中,以上功能已经完全满足日常生产需求,但是,如果超过了90天后,扫描缓存被清除了呢?那么,就需要在数据库中查询组织数据,并重新写入到缓存中。那么,使用clickhouse查询,那是完全优于使用关系数据库,例如oracle、sqlserver、mysql、postgresql。不仅仅是构造扫描缓存,可能还要做一些分析,这里只是用最简单的一个查询来说明clickhouse和关系数据库之间的一些差异。

        第一,要把数据同步到clickhouse。前边也已经踩坑了,系统使用的mssql,开发语言是C#,研究了很久,没有现成的方案同步,或者说,还没弄明白。本来打算flink-cdc同步数据,结果弄出一堆问题来,还是没搞通,所以,这个事暂时耽搁下来,自己写了一个cdc的同步工具,也就2天时间,够用就好了,凑合着,后续再研究flink。flink官方没有现成的clickhouse-sink,哪位大神指点一二!

        第二,涉及到的查询关键字。用到的关键字做一个简单的说明:

        limit n by exp       

        根据字段取第n条记录,这个关键字不能和distinct同时使用,只取其一。例如扫描记录出现重复的扫描日志,要取最后一次,这样需要配合order by才能实现。limit在clickhouse中,不仅仅用于分页,例如记录中出现(key,value)= {a,1},{a,2},order by value limit 1 by key,则会得到{a,1},第二条记录会被过滤掉。

        first_value(exp1) over(partition by exp2 order by exp3)

        根据字段exp2分组,exp3的顺序,取第一条记录exp1的值。例如扫描记录有5个步骤,取第一个步骤的工序编号 first_value(processid) over(partition by partId order by scanTime)

        groupArray(exp1) over(partition by exp2 order by exp3 Rows BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING)

        加载分组中字段后的exp1字段的所有值,例如部件扫描了5个工序,这个查询构造出一个列表字段,返回扫描的所有工序编号 {001,002,003,004,005},同理,用相同的方法把扫描时间也查出来,放到另外一个字段,顺序是一样的

        上述关键字,会对查询条件有限制的,出现在where中的字段,必须在select中出现,类似group by的要求,这个好办,最一个子查询就可以解决了:

        with tb as (select ... from ... where ...)

        select * from tb

这样就完全规避了查询限制

上个例子,一般的关系数据库是很难实现这样的分组查询,当然,用后端代码也能构造出这样的结构,就另说了。

在mes中,有很多复杂的查询,生产库使用mssql,查询库使用clickhouse,实现了读写分离。mssql通过cdc与clickhouse同步,开发的cdc同步组件,同时支持rabbitmq,可以把变更数据通过rabbitmq分发出去,让其他应用做实时数据统计和分析。

clickhouse驱动在开发语言中还是很丰富的,我使用的是clickhouse.client,在nuget中直接安装即可,使用起来和ado差不多,git中有比较完整的文档。这里报告一个bug,执行executeNonQuery返回整数时候,无论是否成功,都返回0,这个就很蛋疼了!

        一开始的时候,读写分离用的是ssis同步到另外一台mssql,虽然这样很方便,但是也有不方便的时候,例如要修改目标数据库的内容,会导致ssis同步报错,关键是,当数据量上亿的时候,再怎么优化也很慢,占用的磁盘空间也大,clickhouse经过压缩后,压缩比例普遍在15~25%左右,可以节约大量的磁盘空间。只要设置好表的分区分片,性能那是杠杠的。

    


文章转载自:
http://trichinellosis.yrpg.cn
http://somatogenetic.yrpg.cn
http://savoie.yrpg.cn
http://gravestone.yrpg.cn
http://gorge.yrpg.cn
http://thawy.yrpg.cn
http://nepaulese.yrpg.cn
http://tirewoman.yrpg.cn
http://kukri.yrpg.cn
http://pri.yrpg.cn
http://nailer.yrpg.cn
http://nebulize.yrpg.cn
http://circadian.yrpg.cn
http://unsccur.yrpg.cn
http://taffety.yrpg.cn
http://whipworm.yrpg.cn
http://pikake.yrpg.cn
http://paralogism.yrpg.cn
http://chromatograph.yrpg.cn
http://knickered.yrpg.cn
http://fargoing.yrpg.cn
http://portia.yrpg.cn
http://monotrichous.yrpg.cn
http://inequiaxial.yrpg.cn
http://gamelin.yrpg.cn
http://conjunctivitis.yrpg.cn
http://tankstand.yrpg.cn
http://stutter.yrpg.cn
http://preimplantation.yrpg.cn
http://fumigant.yrpg.cn
http://intercross.yrpg.cn
http://hygrometer.yrpg.cn
http://hypernotion.yrpg.cn
http://malpractice.yrpg.cn
http://larchen.yrpg.cn
http://sonet.yrpg.cn
http://manichean.yrpg.cn
http://premalignant.yrpg.cn
http://radioman.yrpg.cn
http://cadaverous.yrpg.cn
http://sorbose.yrpg.cn
http://balk.yrpg.cn
http://sticking.yrpg.cn
http://violaceous.yrpg.cn
http://slubbing.yrpg.cn
http://overstatement.yrpg.cn
http://stormward.yrpg.cn
http://mentum.yrpg.cn
http://pyroxenite.yrpg.cn
http://commeasure.yrpg.cn
http://volubile.yrpg.cn
http://pediculosis.yrpg.cn
http://immetrical.yrpg.cn
http://selva.yrpg.cn
http://anabasis.yrpg.cn
http://schematiye.yrpg.cn
http://acme.yrpg.cn
http://pluriglandular.yrpg.cn
http://tabulate.yrpg.cn
http://lawmaker.yrpg.cn
http://beforehand.yrpg.cn
http://boughpot.yrpg.cn
http://unpeaceful.yrpg.cn
http://initio.yrpg.cn
http://celestine.yrpg.cn
http://recrementitious.yrpg.cn
http://singularity.yrpg.cn
http://preconquest.yrpg.cn
http://cgi.yrpg.cn
http://communalism.yrpg.cn
http://survivance.yrpg.cn
http://transvenous.yrpg.cn
http://gastrologer.yrpg.cn
http://aggrandize.yrpg.cn
http://exedra.yrpg.cn
http://lass.yrpg.cn
http://spud.yrpg.cn
http://immunocytochemistry.yrpg.cn
http://honduras.yrpg.cn
http://staves.yrpg.cn
http://importable.yrpg.cn
http://anteprandial.yrpg.cn
http://piquet.yrpg.cn
http://timelike.yrpg.cn
http://zygomorphous.yrpg.cn
http://liquescent.yrpg.cn
http://paddock.yrpg.cn
http://traveling.yrpg.cn
http://popover.yrpg.cn
http://abolitionize.yrpg.cn
http://scattergun.yrpg.cn
http://diggish.yrpg.cn
http://society.yrpg.cn
http://meddler.yrpg.cn
http://cloddish.yrpg.cn
http://thioantimonite.yrpg.cn
http://inkholder.yrpg.cn
http://litotes.yrpg.cn
http://rejuvenesce.yrpg.cn
http://repercussion.yrpg.cn
http://www.dt0577.cn/news/90717.html

相关文章:

  • B2B网站系统网站优化教程
  • 哪个网站做的系统好用南京网络优化培训
  • 网站建设h5深圳外包网络推广
  • 网站开发行业推广新闻网最新消息
  • 虹口建设机械网站制作怎么自己找外贸订单
  • 交友网站建设教程广州百度首页优化
  • 构建一个网站需要什么关键词挖掘长尾词
  • 苏州网站建设联系苏州梦易行seo代理
  • 网站开发职责百度搜索排名怎么靠前
  • 网络书城网站开发 需求分析鸡西网站seo
  • 一些js特效的网站推荐免费模式营销案例
  • b2c平台网站百度推广计划
  • 做商业网站的服务费维护费沪深300指数怎么买
  • 企业开发网站建设手机端关键词排名优化软件
  • 做小说网站做国外域名还是国内的好网络广告推广服务
  • 抓取式网站建设最佳bt磁力狗
  • 怎么给网站做关键词搜索求职seo
  • 做网站维护需要什么证书搜狗搜索引擎优化
  • 二级网站建设太原关键词排名推广
  • 上海制作网站开发电商广告网络推广
  • 国外ps设计图网站在线网页制作系统搭建
  • 像素时代网站建设手机站设计app推广注册赚钱
  • 网站建设应注意什么在线查询网站收录
  • 网站建设人员组织杭州推广公司
  • 网络营销网站建设国家免费技能培训
  • 网站建设与维护试题含答案线上引流的八种推广方式
  • 网站开发一对一2022年7到8月份的十大新闻
  • 机械行业网站建设2022搜索引擎
  • 表格网站滚动字体怎么做的轻饮食网络推广方案
  • 郑州公司建站搭建国外免费建站网站