Quantcast
Channel: IT社区推荐资讯 - ITIndex.net
Viewing all articles
Browse latest Browse all 15843

Hadoop性能调优

$
0
0

重要参数

name说明
mapred.task.profile是否对任务进行profiling,调用java内置的profile功能,打出相关性能信息
mapred.task.profile.{maps|reduces}对几个map或reduce进行profiling。非常影响速度,建议在小数据量上尝试
mapred.job.reuse.jvm.num.tasks1表示不reuse,-1表示无限reuse,其他数值表示每个jvm reuse次数。reuse的时候,map结束时不会释放内存!
mapred.{map|reduce}.tasks.speculative.execution会对运行慢的任务起一个备份任务,看哪个先完成,kill掉后完成的备份
io.sort.spill.percent开始spill的内存比例阈值,对map和reduce都生效
mapred.job.shuffle.input.buffer.percentreduce在copy时使用的堆空间的比例
mapred.tasktracker.{map|reduce}.tasks.maximum一个Tasktracker上可同时运行的最大map、reduce任务数
mapred.reduce.copy.backoffreduce获取一份map输出数据的最大时间,单位秒。
io.compression.codecs压缩算法
dfs.block.sizehdfs上的文件block大小
mapred.reduce.slowstart.completed.maps控制reduce的启动时机。表示全部map的百分之多少完成后,才启动reduce。如果机器内存紧张,可以适当设大改参数,等大部分map结束并释放内存后才启动reduce;如果希望尽快开始shuffle,则可配合大量map数,将该值设小,以尽早启动reduce,开始copy。
io.sort.mbmap使用的缓存,影响spill的次数。
mapred.child.java.opts同时设置map和reduce的jvm参数
mapred.map.child.java.opts分开设置map的jvm参数,包括GC策略
mapred.reduce.child.java.opts分开设置reduce的jvm参数
map.sort.class对map的输出key的排序方法
mapred.output.compression.type压缩类型
mapred.min.split.size每个map的最小输入大小,该值越大,map数越少
mapred.max.split.size每个map的最大输入大小,该值约小,map数越多
mapred.reduce.parallel.copiesreduce从map结果copy数据时,每个reduce起的并行copy线程数。该值越大,io压力越大,但可能引起网络堵塞,copy效率反而降低。
io.sort.factormerge时的并行merge数,同时影响map的spill文件merge和reduce中的merge
mapred.compress.map.output指定map的输出是否压缩。有助于减小数据量,减小io压力,但压缩和解压有cpu成本,需要慎重选择压缩算法。
mapred.map.output.compression.codecmap输出的压缩算法
mapred.output.compressreduce输出是否压缩
mapred.output.compression.codec控制mapred的输出的压缩的方式
io.sort.record.percentmap中间数据的index和data在io.sort.mb中占内存的比例,默认0.05%,需要根据具体数据的特点调整:index的大小固定为16byte,需要根据data的大小调整这个比例,以使io.sort.mb的内存得到充分利用)。

 

 

 

参考:

http://blog.csdn.net/dajuezhao/article/details/6591034



已有 0人发表留言,猛击->> 这里<<-参与讨论


ITeye推荐




Viewing all articles
Browse latest Browse all 15843

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>