1、Hadoop常用命令

hadoop verion       //版本
hadoop fs       //文件系统客户端.
hadoop jar      //
hadoop classpath    //查看hadoop类路径
hadoop checknative  //检查压缩库本地安装情况

hadoop启动命令
$>start-all.sh     //start-dfs.sh + start-yarn.sh

$>start-dfs.sh 相当于后面两个 //hadoop-daemon.sh start namenode
            //hadoop-daemons.sh start datanode

$>start-yarn.sh        //yarn-daemon.sh start resourcemanager
            //yarn-daemons.sh start nodemanager

2、HDFS常用命令

hdfs常用命令
--------------------
$>hdfs dfs -mkdir /user/centos/hadoop   //创建目录
$>hdfs dfs -ls -R /user/centos/hadoop  //递归查看目录中的文件
$>hdfs dfs -lsr /user/centos/hadoop    //递归查看目录中的文件
$>hdfs dfs -put index.html /user/centos/hadoop //上传文件到HDFS中
$>hdfs dfs -get /user/centos/hadoop/index.html a.html  //下载文件到本地
$>hdfs dfs -rm -r -f /user/centos/hadoop   //递归删除目录

注意:hdfs dfs  相当于 Hadoop dfs即操作文件系统
——————————————————————————————————————————————————
对hadoop中name中的镜像文件、编辑日志文件的相关操作

使用oiv命令查询hadoop中name中的镜像文件
hdfs oiv -i fsimage -o a.xml -p XML //查看镜像文件,将其转化为xml格式查看

hdfs dfsadmin管理命令
$>hdfs dfsadmin            //查看帮助
$>hdfs dfsadmin    -help rollEdits //查看指定命令的帮助
$>hdfs dfsadmin -rollEdits //滚动编辑日志
启动hdfs时,镜像文件编辑日志会进行融合,编辑日志滚动

查看hdfs是否在安全模式,安全模式不能对日志文件等进行删除和修改
$>hdfs dfsadmin -safemode  enter       //进入
$>hdfs dfsadmin -safemode  get         //查看
$>hdfs dfsadmin -safemode  leave       //退出
$>hdfs dfsadmin -safemode  wait            //等待

保存名字空间(一般用来创建检查点),需要进入安全模式,启动完成自动进入安全模式
$>hdfs dfsamdin -saveNamespace
——————————————————————————————————————
配额管理(quota)
[目录配额]使得目录下的存储文件总数得到一定的控制
计算目录下的所有文件的总个数。如果1,表示空目录。
$>hdfs dfsadmin -setQuota 1 dir1 dir2      //设置目录配额
$>hdfs dfsadmin -clrQuota 1 dir1 dir2      //清除配额管理

[空间配额]
计算目录下的所有文件的总大小.包括副本数.
空间配置至少消耗3倍的空间大小(目录本身会占用3倍的空间)。
$>hdfs dfsadmin -setSpaceQuota 3 data
$>hdfs dfsadmin -clrSpaceQuota dir1        //清除配额管理

————————————————————————————————————————
快照管理
1.描述
迅速对文件(夹)进行备份。不产生新文件,使用差值存储。
默认是禁用快照,先启用。

2.命令
$>hdfs dfsadmin -allowSnapShot dir1    //在dir1启用快照
$>hdfs dfsadmin -disallowSnapShot dir1 //在dir1禁用快照
$>hdfs dfs -createSnapshot dir ss1 //创建快照
$>hdfs dfs -renameSnapshot dir ss1 ss2 //重命名
$>hdfs dfs -deleteSnapshot dir ss1 //删除快照

3、HDFS默认为64M,一般设置为128M
之所以设置为128M是为了提高效率,让寻址时间占用读取时间的1%,寻址时间大概为10ms左右,而磁盘的读取时间一般为100M/s,所以为了满足寻址时间占用读取时间的1%,一般设置为128M。当文件切割得太小会使得寻址大于读取时间的1%,不利于效率的提升。

HDFS不适合存储大量的小文件,因为小文件会使得namenode增大,namenode只负责datanode的归档管理,存储的是datanode块中文件的索引,每个文件大概索引字节为152个,不管大小,都一样,所以当文件过小,存储的数据少但是耗费的资源却一样,存储的性价比高。并且namenode是运行在内存中的,内存资源相对宝贵,理应让它发挥最大的效益。

配置hadoop的最小blocksize,必须是512的倍数。

[hdfs-site.xml]
dfs.namenode.fs-limits.min-block-size=1024
write,进行校验,512进行一次校验。

默认最小块是1M,当我们通过API进行设置时也要大于1M,除非手动修改hadoop的默认配置文件,即hdfs-default.xml,一般不建议这么做。

单独配置辅助名称节点

[hdfs-site.xml]
dfs.namenode.secondary.http-address=s206:50090

4、DataNode、Yarn节点服役、退役

DataNode的服役:当某个DataNode节点挂掉之后,需要有个新节点自动补上,以达到设置的节点副本数(一般设置为3个副本)。通过黑白名单以及Slaves文件来对它进行控制,Slaves文件只是在集群启动的时候,集群会通过读取Slaves文件来启动相应的DataNode,而并非直接由Slaves控制。

黑白名单的组合情况,不需要分发到其他节点上,只要存储在namenode节点上即可。

include     //dfs.hosts    白名单
exclude     //dfs.hosts.exclude 黑名单

include     exclude     Interpretation
No          No          不能连接
No          Yes         不能连接
Yes         No          可以连接
Yes         Yes         可以连接,将会退役状态。

节点的服役和退役(hdfs)

[服役]

[添加新节点]
1.在dfs.include文件中包含新节点名称,该文件在nn的本地目录。

[白名单]
[s201:/soft/hadoop/etc/dfs.include.txt]
s202
s203
s204
s205

2.在hdfs-site.xml文件中添加属性.(这个是早就配置好了的)

<property>
    <name>dfs.hosts</name>
    <value>/soft/hadoop/etc/dfs.include.txt</value>
</property>

3.在nn上刷新节点(当要添加新节点的时候,而又不能停止集群运行,只能通过黑白名单的方式来维护3个副本的存在)

$>hdfs dfsadmin -refreshNodes

4.在slaves文件中添加新节点ip(主机名)(以便后面重新启动集群的时候自动寻找新服役的节点)

s202
s203
s204
s205        //新添加的

5.单独在新节点的机器上启动新的节点中的datanode

[s205]
$>hadoop-daemon.sh start datanode

[退役]
1.添加退役节点的ip到黑名单,不要更新白名单.

[/soft/hadoop/etc/dfs.hosts.exclude.txt]
s205

2.配置hdfs-site.xml

<property>
    <name>dfs.hosts.exclude</name>
    <value>/soft/hadoop/etc/dfs.hosts.exclude.txt</value>
</property>

3.刷新nn节点

$>hdfs dfsadmin -refreshNodes

4.查看webui,节点状态在decommisstion in progress.
5.当所有的要退役的节点都报告为Decommissioned,数据转移工作已经完成。
6.从白名单删除节点,并刷新节点

[s201:/soft/hadoop/etc/dfs.include.txt]
        ...

$>hdfs dfsadmin -refreshNodes

7.从slaves文件中删除退役节点

节点的服役和退役(yarn)
[添加新节点]
1.在dfs.include文件中包含新节点名称,该文件在nn的本地目录。

[白名单]
[s201:/soft/hadoop/etc/yarn.include.txt]
s202
s203
s204
s205

2.在yarn-site.xml文件中添加属性.

<property>      <name>yarn.resourcemanager.nodes.include-path</name>
    <value>/soft/hadoop/etc/dfs.include.txt</value>
</property>

3.在nn上刷新节点

$>yarn rmadmin -refreshNodes

4.在slaves文件中添加新节点ip(主机名)

s202
s203
s204
s205        //新添加的

5.单独启动新的节点中的nodemananger

[s205]
$>yarn-daemon.sh start nodemananger

[退役]
1.添加退役节点的ip到黑名单,不要更新白名单.

[/soft/hadoop/etc/yarn.exclude.txt]
s205

2.配置yarn-site.xml

<property>
    <name>yarn.resourcemanager.nodes.exclude-path</name>
    <value>/soft/hadoop/etc/dfs.hosts.exclude.txt</value>
</property>

3.刷新rm节点

$>yarn rmadmin -refreshNodes

4.查看webui,节点状态在decommisstion in progress.

5.当所有的要退役的节点都报告为Decommissioned,数据转移工作已经完成。

6.从白名单删除节点,并刷新节点

$>yarn rmadmin -refreshNodes

7.从slaves文件中删除退役节点