收藏本页 | 设为主页 | 贸易商务资源网首页 | 免费注册 | 会员登录 | 忘记密码? | 供应 | 求购 | 公司 | 展会 | 资讯 | 图库 | 新发布 | 新更新 | 物流 | 手机版 | 升级商家通
免费会员

北京千锋互联科技有限公司

JAVA、全栈HTML5+、PHP、python人工智能+全栈、UI、大数据、软件测试、Linux云计算...

更多产品分类
  • 暂无分类
站内搜索
 
 
更多友情链接
商家通 通天下
想拥有精美网站和更多的询盘订单?立即注册升级为商家通会员!生意旺旺!需要帮助欢迎与我们取得联系
您当前的位置:首页 » 新闻中心 » 千锋重庆java培训班
新闻分类
新闻中心

千锋重庆java培训班

发布时间:2018-03-18 15:39:43       返回列表
  

千锋重庆java培训班

Java在处理数据量比较大的时候,加载到内存必然会导致内存溢出,而在一些数据处理中我们不得不去处理海量数据,那Java是如何处理大数据的呢?有什么技巧吗?在做数据处理中,我们常见的手段是分解,压缩,并行,临时文件等方法。

例如,我们要将数据库(不论是什么数据库)的数据导出到一个文件,一般是Excel或文本格式的CSV;对于Excel来讲,对于POIJXL的接口,你很多时候没有办法去控制内存什么时候向磁盘写入,很恶心,而且这些API在内存构造的对象大小将比数据原有的大小要大很多倍数,所以你不得不去拆分Excel,还好,POI开始意识到这个问题,在nth="12" day="30" islunardate="False" isrocdate="False" w:st="on">3.8.4的版本后,开始提供cache的行数,提供了SXSSFWorkbook的接口,可以设置在内存中的行数,不过可惜的是,他当你超过这个行数,每添加一行,它就将相对行数前面的一行写入磁盘(如你设置2000行的话,当你写第20001行的时候,他会将**行写入磁盘),其实这个时候他些的临时文件,以至于不消耗内存,不过这样你会发现,刷磁盘的频率会非常高,我们的确不想这样,因为我们想让他达到一个范围一次性将数据刷如磁盘,比如一次刷1M之类的做法,可惜现在还没有这种API,很痛苦,我自己做过测试,通过写小的Excel比使用目前提供刷磁盘的API来写大文件,效率要高一些,而且这样如果访问的人稍微多一些磁盘IO可能会扛不住,因为IO资源是非常有限的,所以还是拆文件才是上策;而当我们写CSV,也就是文本类型的文件,我们很多时候是可以自己控制的,不过你不要用CSV自己提供的API,也是不太可控的,CSV本身就是文本文件,你按照文本格式写入即可被CSV识别出来;如何写入呢?下面来说说。。。

在处理数据层面,如从数据库中读取数据,生成本地文件,写代码为了方便,我们未必要1M怎么来处理,这个交给底层的驱动程序去拆分,对于我们的程序来讲我们认为它是连续写即可;我们比如想将一个1000W数据的数据库表,导出到文件;此时,你要么进行分页,Oracle当然用三层包装即可,MySQLlimit,不过分页每次都会新的查询,而且随着翻页,会越来越慢,其实我们想拿到一个句柄,然后向下游动,编译一部分数据(如10000行)将写文件一次(写文件细节不多说了,这个是**基本的),需要注意的时候每次buffer的数据,在用outputstream写入的时候,**flush一下,将缓冲区清空下。

来设置游标的方式,以至于游标不是将数据直接cache到本地内存,然后通过设置statement.setFetchSize(200);设置游标每次遍历的大小;OK,这个其实我用过,oracle用了和没用没区别,因为oraclejdbc API默认就是不会将数据cachejava的内存中的,而mysql里头设置根本无效,我上面说了一堆废话,呵呵,我只是想说,java提供的标准API也未必有效,很多时候要看厂商的实现机制,还有这个设置是很多网上说有效的,但是这纯属抄袭;对于oracle上面说了不用关心,他本身就不是cache到内存,所以java内存不会导致什么问题,如果是mysql,首先必须使用5以上的版本,然后在连接参数上加上useCursorFetch=true这个参数,至于游标大小可以通过连接参数上加上:defaultFetchSize=1000来设置,

上次被这个问题纠结了很久(mysql的数据老导致程序内存膨胀,并行2个直接系统就宕了),还去看了很多源码才发现奇迹竟然在这里,**后经过mysql文档的确认,然后进行测试,并行多个,而且数据量都是500W以上的,都不会导致内存膨胀,GC一切正常,这个问题终于完结了。

Java在处理大数据的时候还是有一些小技巧的,正确运用这些小技巧,有时候在处理问题时往往会事半功倍。更多Java的学习尽在千锋教育,千锋教育的Java课程有四个阶段的学习,四个阶段让大牛讲师带你精通掌握Java技术。

千锋教育:http://www.mobiletrain.org/

千锋重庆校区:http://cq.mobiletrain.org/

重庆校区地址:重庆市高新区科园一路2号大西洋国际12-1

培训咨询专线:023-68883009

    QQ  : 1660794050

面授课程:全栈HTML5+培训、全链路设计培训、PHP全栈+服务器集群培训、JavaEE+分布式开发培训、大数据+人工智能培训、 Unity游戏开发培训、Python培训、云计算+Python运维培训、全栈软件测试培训、Android培训、iOS培训

 

 

千锋重庆java培训班

http://imissyou159.ceoie.com/news/itemid-3927889.shtml,我们主要有JAVA、全栈HTML5+、PHP、python人工智能+全栈、UI、大数据、软件测试、Linux云计算、VR/AR、安卓、IOS ,欢迎与我联系:联系人,李老师,手机:400-186-9990,我将向您提供更多【千锋重庆java培训班】详细信息。