【解决】关于Yarn资源管理的问题

查看数: 12720 | 评论数: 4 | 收藏 1
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2014-12-22 16:31

正文摘要:

本帖最后由 lixiaoliang7 于 2014-12-22 18:31 编辑 这是我的测试集群。 请问,每个节点中Mem Avail的1G内存就代表NodeManager中的最大内存吗? NodeManager最大内存如果是1G, 那么代表节点下跑的map ...

回复

gefieder 发表于 2014-12-22 18:10:33
合不合理,这个需要自己测试下本机环境
ainubis 发表于 2015-3-28 17:24:50
很牛的资料
lixiaoliang7 发表于 2014-12-22 18:18:32
gefieder 发表于 2014-12-22 18:10
合不合理,这个需要自己测试下本机环境

多谢分享您的经验。
gefieder 发表于 2014-12-22 17:55:10
本帖最后由 gefieder 于 2014-12-22 17:59 编辑
Yarn集群的内存分配配置在yarn-site.xml文件中配置:
  1. <property>
  2.     <name>yarn.nodemanager.resource.memory-mb</name>
  3.     <value>22528</value>
  4.     <discription>每个节点可用内存,单位MB</discription>
  5.   </property>
  6.   
  7.   <property>
  8.     <name>yarn.scheduler.minimum-allocation-mb</name>
  9.     <value>1500</value>
  10.     <discription>单个任务可申请最少内存,默认1024MB</discription>
  11.   </property>
  12.   
  13.   <property>
  14.     <name>yarn.scheduler.maximum-allocation-mb</name>
  15.     <value>16384</value>
  16.     <discription>单个任务可申请最大内存,默认8192MB</discription>
  17.   </property>
复制代码



由于我Yarn集群还需要跑Spark的任务,而Spark的Worker内存相对需要大些,所以需要调大单个任务的最大内存(默认为8G)。
而Mapreduce的任务的内存配置:
  1. <property>
  2.     <name>mapreduce.map.memory.mb</name>
  3.     <value>1500</value>
  4.     <description>每个Map任务的物理内存限制</description>
  5.   </property>
  6.   
  7.   <property>
  8.     <name>mapreduce.reduce.memory.mb</name>
  9.     <value>3000</value>
  10.     <description>每个Reduce任务的物理内存限制</description>
  11.   </property>
  12.   
  13.   <property>
  14.     <name>mapreduce.map.java.opts</name>
  15.     <value>-Xmx1200m</value>
  16.   </property>
  17.   
  18.   <property>
  19.     <name>mapreduce.reduce.java.opts</name>
  20.     <value>-Xmx2600m</value>
  21.   </property>
复制代码


  1. mapreduce.map.memory.mb:每个map任务的内存,应该是大于或者等于Container的最小内存。
  2. 按照上面的配置:每个slave可以运行map的数据<= 22528/1500,reduce任务的数量<=22528/3000
复制代码




关闭

推荐上一条 /2 下一条