将编写好的xsync脚本文件放在/home/atguigu/bin目录下,因为这个路径已经在path变量里面了。之后可以随便在哪个目录下执行xsync命令
增加xsync脚本文件的执行权
chmod +x xsync
在任何位置敲击xsy,之后按一下tab键,就可以自动打出xsync
data:image/s3,"s3://crabby-images/b6c0a/b6c0ab03b13c51fb4cce0526e045b50ffe1f26bc" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
分布式模式集群的规划
data:image/s3,"s3://crabby-images/83765/837653c88a846c91a269ae1afac23fcfcf83aaea" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
第一步:配置core-site.xml,操作hadoop102,之后分发
data:image/s3,"s3://crabby-images/16ec4/16ec47945c62105c5d96a6e0b213ba1053202ce2" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/c430c/c430cd6bb4b4a377fe772c817b92b6a55424f513" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/aedeb/aedeb595693911973d873d0258bc7b3c68c422c2" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/567b5/567b5d1b803244d3a79c6221c72b3d38d8108770" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/fb64d/fb64d794977205cbecfea5e0535a9aed9b096320" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
<!-- 指定NameNode的地址 -->
<property>
<name>fs.defaultFS</name>
<value>hdfs://hadoop102:9820</value>
</property>
<!-- 指定hadoop数据的存储目录
官方配置文件中的配置项是hadoop.tmp.dir ,用来指定hadoop数据的存储目录,此次配置用的hadoop.data.dir是自己定义的变量, 因为在hdfs-site.xml中会使用此配置的值来具体指定namenode 和 datanode存储数据的目录
-->
<property>
<name>hadoop.data.dir</name>
<value>/opt/module/hadoop-3.1.3/data</value>
</property>
<!-- 下面是兼容性配置,先跳过 -->
<!-- 配置该atguigu(superUser)允许通过代理访问的主机节点 -->
<property>
<name>hadoop.proxyuser.atguigu.hosts</name>
<value>*</value>
</property>
<!-- 配置该atguigu(superuser)允许代理的用户所属组 -->
<property>
<name>hadoop.proxyuser.atguigu.groups</name>
<value>*</value>
</property>
<!-- 配置该atguigu(superuser)允许代理的用户-->
<property>
<name>hadoop.proxyuser.atguigu.users</name>
<value>*</value>
</property>
2、配置hdfs-site.xml文件
<!-- 指定NameNode数据的存储目录 -->
<property>
<name>dfs.namenode.name.dir</name>
<value>file://${hadoop.data.dir}/name</value>
</property>
<!-- 指定Datanode数据的存储目录 -->
<property>
<name>dfs.datanode.data.dir</name>
<value>file://${hadoop.data.dir}/data</value>
</property>
<!-- 指定SecondaryNameNode数据的存储目录 -->
<property>
<name>dfs.namenode.checkpoint.dir</name>
<value>file://${hadoop.data.dir}/namesecondary</value>
</property>
<!-- 兼容配置,先跳过 -->
<property>
<name>dfs.client.datanode-restart.timeout</name>
<value>30</value>
</property>
<!-- nn web端访问地址-->
<property>
<name>dfs.namenode.http-address</name>
<value>hadoop102:9870</value>
</property>
<!-- 2nn web端访问地址-->
<property>
<name>dfs.namenode.secondary.http-address</name>
<value>hadoop104:9868</value>
</property>
data:image/s3,"s3://crabby-images/140aa/140aa1be94316198289d34dff64ea762172f8a6a" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/ec1ed/ec1ededd03c9bf7d317c869151c250f191c467bf" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/83bc4/83bc48f3a69c9118231b26f138757814af21f222" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
/opt/module/hadoop-3.1.3/data
data:image/s3,"s3://crabby-images/46c1a/46c1a2451a5de5aa5e8e0bd73914b90e4218eae4" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/8b460/8b460439ddf933f90589340a3e0cb46cfaeb12d3" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/a14e6/a14e684beb80b17abf8dd275b372ab136de4d3e0" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
3、配置yarn-site.xml
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
<!-- 指定ResourceManager的地址-->
<property>
<name>yarn.resourcemanager.hostname</name>
<value>hadoop103</value>
</property>
<!-- 环境变量的继承 -->
<property>
<name>yarn.nodemanager.env-whitelist</name>
<value>JAVA_HOME,HADOOP_COMMON_HOME,HADOOP_HDFS_HOME,HADOOP_CONF_DIR,CLASSPATH_PREPEND_DISTCACHE,HADOOP_YARN_HOME,HADOOP_MAPRED_HOME</value>
</property>
</configuration>
data:image/s3,"s3://crabby-images/79486/79486651b91f7c043177a634fb7135a693a79ac2" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/73151/73151f6bb66d1817cfb80a0d849cbccb31d30f51" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
4、配置mapred-site.xml文件
<configuration>
<!--指定MapReduce程序运行在Yarn上 -->
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
data:image/s3,"s3://crabby-images/47fd8/47fd802995fc7ea0061c1112663c2413e954eaa4" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
所有在102上配置的东西全部分发一下
直接分发hadoop目录/opt/module/hadoop-3.1.3/etc/hadoop
data:image/s3,"s3://crabby-images/bd742/bd742b3ea6b81c1a61bed85837830000be02a4b8" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/1e2e6/1e2e6752afe492245f8cb08843715c2e06a76d5b" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
这里我们就已经配置好所有的文件了
单点启动集群:
因为,集群是新搭建的,需要在第一次启动的时候先在namenode所在的节点去格式化一下
hdfs namenode -formate
在/opt/module/hadoop-3.1.3目录下去格式化,格式化之后会在这个目录下生成一个data目录
data:image/s3,"s3://crabby-images/5d552/5d552c9a8a110ac15cbe20d8c42c49e7cc27c849" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/5670f/5670f952e1457a62901ab9fb5a48de8cdd662c49" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/a4ec7/a4ec750b2052124baaf40dbc98795e4ac76adc41" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
1、在hadoop102上启动namenode
hdfs --daemon start namenode
查看浏览器页面
输入hadoop102:9870
data:image/s3,"s3://crabby-images/80ea0/80ea0fcd42ac0007849e632da6b699dc82e411ad" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/8858f/8858fc25e6a73888e9c8842316a90969b4f14930" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/16281/16281d6c620f7cfd1ac0d3b3adfc682221beb71d" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
2、在hadoop104上启动secondarynode
hdfs --daemon start secondarynamenode
data:image/s3,"s3://crabby-images/18516/185166a987c43507fe24c14e01401eaff70d9ff0" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/0faa3/0faa31a23a13b1ede52939002c1545f8fa82199e" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
2nn页面我们一般不会去访问这个web页面。没意义在hadoop102 103 104分别启动datanode
hdfs --daemon start dateanode
data:image/s3,"s3://crabby-images/1bf21/1bf211130605e3322f5537bf240111ce8384f124" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/bed4c/bed4c243e2edf3fa52015cb4e754e1763ea5af4e" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/c0b1a/c0b1acad9c9b348d829e8e431324fce5dd590022" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/13d9c/13d9cd865f77df7cae3e42efd5771b339bcebd91" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
data:image/s3,"s3://crabby-images/02e2a/02e2a7307fee8bf6383da62710a9f3f6feaebdb7" alt="hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs hadoop学习从编写分发脚本实现集群里所有机器的同步到实现单点启动hdfs"
这个时候就已经成功实现了单点启动hdfs