hadoop的基本命令与Linux命令很相似,这里列举一下基本的HDFS命令。
命令基本格式:
hadoop fs -cmd < args >
但建议使用以下格式:
hdfs dfs -cmd < args >
1、ls
列出hdfs文件系统根目录下的目录和文件:
hadoop fs -ls /
列出hdfs文件系统所有的目录和文件:
hadoop fs -ls -R /
注:“/”可以是任意文件路径经。
2、put
格式为:
hadoop fs -put < local file > < hdfs file >
注:hdfs dir 一定要存在,否则命令不会执行
从键盘读取输入到hdfs file中,按Ctrl+D结束输入,hdfs file不能存在,否则命令不会执行
hadoop fs -put - < hdsf file>
hadoop fs -put Data.txt /SparkTestData #将Data.txt文件放到SparkTestData中
2.1.moveFromLocal
hadoop fs -moveFromLocal < local src > ... < hdfs dst >
注:与put相类似,命令执行后源文件 local src 被删除,也可以从从键盘读取输入到hdfs file中
2.2.copyFromLocal
hadoop fs -copyFromLocal < local src > ... < hdfs dst >
注:与put相类似,也可以从从键盘读取输入到hdfs file中
3.get
hadoop fs -get < hdfs file > < local file or dir>
注:local file不能和 hdfs file名字相同,否则会提示文件已存在,没有重名的文件会复制到本地
hadoop fs -get < hdfs file or dir > ... < local dir >
拷贝多个文件或目录到本地时,本地要为文件夹路径
注意:如果用户不是root, local 路径要为用户文件夹下的路径,否则会出现权限问题
3.1、copyToLocal
hadoop fs -copyToLocal < local src > ... < hdfs dst >
注:与get相类
4.rm
hadoop fs -rm < hdfs file > ...
hadoop fs -rm -r < hdfs dir>...
注:每次可以删除多个文件或目录
5.mkdir
hadoop fs -mkdir < hdfs path>
注:只能一级一级的建目录,父目录不存在的话使用这个命令会报错
hadoop fs -mkdir -p < hdfs path>
注:所创建的目录如果父目录不存在就创建该父目录
如果不指明父级目录,则默认在/user/hadoop/的父级目录下创建文件夹,即如果使用如下命令
hadoop fs -mkdir SparkTestData
则系统在/user/hadoop/下创建SparkTestData文件夹
如若直接在集群创建文件夹,而不是在/user/hadoop/下创建,要带上hdfs的端口,命令如下:
hadoop fs -mkdir hdfs://master:9000/SparkTestData
在HDFS上创建SparkTestData文件夹
6、cp
hadoop fs -cp < hdfs file > < hdfs file >
注:目标文件不能存在,否则命令不能执行,相当于给文件重命名并保存,源文件还存在
7、mv
hadoop fs -mv < hdfs file > < hdfs file >
注:目标文件不能存在,否则命令不能执行,相当于给文件重命名并保存,源文件不存在
hadoop fs -mv < hdfs file or dir >... < hdfs dir >
注:源路径有多个时,目标路径必须为目录,且必须存在。
注意:跨文件系统的移动(local到hdfs或者反过来)都是不允许的
8、archive
hadoop archive -archiveName name.har -p < hdfs parent dir > < src >* < hdfs dst >
命令中参数name:压缩文件名,自己任意取;< hdfs parent dir > :压缩文件所在的父目录;< src >:要压缩的文件名;< hdfs dst >:压缩文件存放路径
示例:hadoop archive -archiveName hadoop.har -p /user 1.txt 2.txt /des
示例中将hdfs中/user目录下的文件1.txt,2.txt压缩成一个名叫hadoop.har的文件存放在hdfs中/des目录下,如果1.txt,2.txt不写就是将/user目录下所有的目录和文件压缩成一个名叫hadoop.har的文件存放在hdfs中/des目录下
显示har的内容可以用如下命令:
hadoop fs -ls /des/hadoop.jar
显示har压缩的是那些文件可以用如下命令
hadoop fs -ls -R har:///des/hadoop.har
注意:har文件不能进行二次压缩。如果想给.har加文件,只能找到原来的文件,重新创建一个。har文件中原来文件的数据并没有变化,har文件真正的作用是减少NameNode和DataNode过多的空间浪费。
注:本命令暂不齐全。