添加节点

1.修改host 
  和普通的datanode一样。添加namenode的ip
2.修改namenode的配置文件conf/slaves 
  添加新增节点的ip或host
3.在新节点的机器上,启动服务

[root@slave-004 Hadoop]# ./bin/hadoop-daemon.sh start datanode[root@slave-004 hadoop]# ./bin/hadoop-daemon.sh start tasktracker

4.均衡block

[root@slave-004 hadoop]# ./bin/start-balancer.sh

1)如果不balance,那么cluster会把新的数据都存放在新的node上,这样会降低mapred的工作效率 
2)设置平衡阈值,默认是10%,值越低各节点越平衡,但消耗时间也更长

[root@slave-004 hadoop]# ./bin/start-balancer.sh -threshold 5

3)设置balance的带宽,默认只有1M/s
 <property>

   <name>dfs.balance.bandwidthPerSec</name>  

   <value>1048576</value>  

  <description>  

     Specifies the maximum amount of bandwidth that each datanode   

     can utilize for the balancing purpose in term of   

     the number of bytes per second.   

   </description> 

</property>
注意: 
1. 必须确保slave的firewall已关闭; 
2. 确保新的slave的ip已经添加到master及其他slaves的/etc/hosts中,反之也要将master及其他slave的ip添加到新的slave的/etc/hosts中

删除节点

1.集群配置 
   修改conf/hdfs-site.xml文件
 <property>
  <name>dfs.hosts.exclude</name>
  <value>/data/soft/hadoop/conf/excludes</value>
  <description>
Names a file that contains a list of hosts that are
   not permitted to connect to the namenode. The full pathname of the
  file must be specified. If the value is empty, no hosts are
  excluded.
</description>
</property>
2确定要下架的机器 
dfs.hosts.exclude定义的文件内容为,每个需要下线的机器,一行一个。这个将阻止他们去连接Namenode。如:

slave-003  slave-004

3.强制重新加载配置

[root@master hadoop]# ./bin/hadoop dfsadmin  -refreshNodes

它会在后台进行Block块的移动
4.关闭节点 
等待刚刚的操作结束后,需要下架的机器就可以安全的关闭了。

[root@master hadoop]# ./bin/ hadoop dfsadmin -report

可以查看到现在集群上连接的节点

正在执行Decommission,会显示: Decommission Status : Decommission in progress  执行完毕后,会显示: Decommission Status : Decommissioned

5.再次编辑excludes文件 
一旦完成了机器下架,它们就可以从excludes文件移除了 
登录要下架的机器,会发现DataNode进程没有了,但是TaskTracker依然存在,需要手工处理一下

http://www.dataguru.cn/forum.php?mod=viewthread&tid=175348

最新文章

  1. ROC曲线、PR曲线
  2. kafka性能参数和压力测试揭秘
  3. PCB板的质量可接受性标准 IPC-A-600H 中文版下载
  4. MYSQL相关完整笔记
  5. 苹果浏览器和uc浏览器在移动端的坑(日常积累,随时更新)
  6. Nodejs电影建站开发实例(上)
  7. js中获取样式的俩种方法 style.color和style[&#39;color&#39;] 区别
  8. PHP如何返回json格式的数据
  9. 【转】第一次使用Android Studio时你应该知道的一切配置(三):gradle项目构建
  10. WEB中调用Nutch执行JOB抓取
  11. Three.js three.js Uncaught TypeError: Cannot read property &#39;getExtension&#39; of null
  12. OpenStack 与 Rancher
  13. centos7下rsync+crontab定期同步备份
  14. python 文本特征提取 CountVectorizer, TfidfVectorizer
  15. struts2常用标签详解(申明:来源于网络)
  16. Spring Boot源码分析
  17. MS SQL Server字符拆分函数
  18. 【java规则引擎】《Drools7.0.0.Final规则引擎教程》第3章 3.2 KIE API解析
  19. SDK Build Tools revision (19.0.3) is too low for project Minimum required is 19.1.0
  20. ubuntu:NVIDIA设置性能模式,以降低CPU使用、温度

热门文章

  1. [转]Cordova - 彻底搞定IOS编译!
  2. webapi 控制json的字段(key)显示顺序
  3. c# 画布验证码
  4. HTML设为首页/加入收藏代码
  5. Mybatis框架基础支持层——反射工具箱之Reflector&amp;ReflectorFactory(3)
  6. 大数据Spark与Storm技术选型
  7. 关于openSetting通过tap的调用
  8. MySQL 内置函数
  9. 【20190220】JavaScript-知识点整理:对象创建方式、原型、闭包
  10. JMeter&#160;配置元件之HTTP&#160;Cookie&#160;Manager&#160;介绍