实验目的

了解java的安装配置

学习配置对自己节点的免密码登陆

了解hdfs的配置和相关命令

了解yarn的配置

实验原理

1.Hadoop安装  
  Hadoop的安装对一个初学者来说是一个很头疼的事情,要一步安装好整个hadoop集群难度特别大,所以一个快捷的学习方法是边安装边学习,安装的时候,先搭建单节点伪分布式,然后再搭建完全分布式,最后搭建高可用的分布式集群,如果有兴趣,还可以研究怎么使用CDH搭建超大规模的集群。
  安装之前,首先需要懂一个概念:hadoop有三个部分,hdfs、mapreduce、yarn,其中mapreduce就是一堆java的jar包,不需要安装,而hdfs和yarn是需要安装的。伪分布式在一个节点上安装,实际上是将hdfs的namenode、secondary namenode、datanode和yarn的nodemanager、resource manager放在一台节点上。
  安装伪分布式的步骤在Hadoop官网上有介绍,我们就按照官网的介绍一步一步来。

首先安装java;

配置当前用户自己对自己的免密码登陆;

安装Hadoop并配置相关配置文件。

2.Hadoop配置文件说明:
  1、dfs.hosts 记录即将作为datanode加入集群的机器列表
  2、mapred.hosts 记录即将作为tasktracker加入集群的机器列表
  3、dfs.hosts.exclude mapred.hosts.exclude 分别包含待移除的机器列表
  4、master 记录运行辅助namenode的机器列表
  5、slave 记录运行datanode和tasktracker的机器列表
  6、hadoop-env.sh 记录脚本要用的环境变量,以运行hadoop
  7、core-site.xml hadoop core的配置项,例如hdfs和mapreduce常用的i/o设置等
  8、hdfs-site.xml hadoop守护进程的配置项,包括namenode、辅助namenode和datanode等
  9、mapred-site.xml mapreduce守护进程的配置项,包括jobtracker和tasktracker
  10、hadoop-metrics.properties 控制metrics在hadoop上如何发布的属性
  11、log4j.properties 系统日志文件、namenode审计日志、tasktracker子进程的任务日志的属性

3.格式化HDFS文件系统
  在能够使用之前,全新的HDFS安装需要进行格式化。通过创建存储目录和初始版本的namenode持久数据结构,格式化进程将创建一个空的文件系统。由于namenode管理所有的文件系统元数据,datanode可以动态加入和离开集群。所以初始的格式化进程不涉及到datanode。同样原因,创建文件系统时也无需指定大小,这是有集群中的datanode数目决定的,在文件系统格式化之后的很长时间内都可以根据需要增加。
  格式化HDFS是一个快速操作。以hdfs用户身份运行一下命令:

hdfs namenode -format

4.启动和停止守护进程
  Hadoop自带脚本。可以运行命令并在整个集群范围内启动和停止守护进程。为使用这些脚本(在sbin目录下),需要告诉Hadoop集群中有哪些机器。文件slaves正式用于此目的,该文件包含了机器主机名或IP地址的列表,每行代表一个机器信息。文件slaves列举了可以运行的datanode和节点管理器的机器。文件驻留在Hadoop配置目录下,尽管通过修改hadoop-env.sh中的HADOOP_SLAVES设置可能会将文件放在别的地方(并赋予一个别的名称)。并且,不需要将该文件分发给工作节点,因为仅有运行在namenode和资源管理器上的控制脚本使用它。
  1)以HDFS用户身份运行以下命令可以启动HDFS守护进程:

start-dfs.sh

  namenode和辅助namenode运行所在的机器通过向Hadoop配置询问机器主机名来决定。通过以下命令,脚本能够找到namenode的主机名。

hdfs getconf -namenodes

  默认情况下,该命令从fs.defaultFS中找到namenode的主机名。更具体一些,start-dfs.sh脚本所做的事情如下:

1.在每台机器上启动一个namenode,这些机器由执行hdfs getconf -namenodes得到的返回值所确定。

2.在slaves文件列举的每台机器上启动一个datanode。

3.在每台机器上启动一个辅助namenode,这些由执行hdfs get conf-secondarynamenodes得到的返回值所确定。

  2)YARN守护进程以相同方式启动,通过以yarn用户的身份在托管资源管理器的机器上运行以下 命令:

start-yarn.sh

  这种情况下,资源管理器总是和start-yarn.sh脚本运行在同意机器上。脚本明确完成以下事情:

1.在本地机器上启动一个资源管理器。

2.在slaves文件列举的每台机器上启动一个节点管理器。

  同样,还提供了stop-dfs.sh和stop-yarn.sh脚本用于停止由相应的启动脚本启动的守护进程。

实验环境

1.操作系统
  操作机1:Linux_Centos
  操作机2:Windows_7
  操作机1默认用户名:root,密码:123456
  操作机2默认用户名:hongya,密码:123456

步骤1:使用xshell进行连接

  1.1进入操作机2,点击xshell,新建会话。

名称:standalone

主机:90.10.10.42

1.2点击“用户身份验证”,输入用户名和密码,点击确定。

用户名:root

密码:123456

1.3会话已经建立,选中之后,点击“连接”。可以看到连接成功。

步骤2:添加映射,免密码登陆

  2.1添加映射。

vi /etc/hosts

2.2免密码登陆。

ssh-keygen

  输入后,会提示创建.ssh/id_rsa、id_rsa.pub的文件,其中第一个为密钥,第二个为公钥。过程中会要求输入密码,为了ssh访问过程无须密码,可以直接回车 。

  将公钥写入standalone认证文件。

ssh-copy-id standalone

步骤3:解压安装Hadoop,配置Hadoop-env.sh

  3.1首先解压安装包,并将其复制到/home/hadoop/tmp/目录下。

tar -zxvf /opt/pkg/hadoop-2.6.0-cdh5.5.2.tar.gz -C /home/hadoop/tmp/

3.2进入配置文件目录,在hadoop安装目录的/etc/hadoop下。

cd /home/hadoop/tmp/hadoop-2.6.0-cdh5.5.2/etc/hadoop

ls

3.3修改hadoop-env.sh配置。

vim hadoop-env.sh

  修改JDK路径为:

export JAVA_HOME=/home/hadoop/tmp/soft/jdk1.8.0_121

保存退出。

步骤4:配置hdfs并启动

  4.1在相同目录下,我们修改core-site.xml的配置。

vim core-site.xml

  添加内容:

<property>

<!-- 配置集群的地址,这个standalone是本地ip -->

<name>fs.defaultFS</name>

<value>hdfs://standalone:9000</value>

</property>

<property>

<!-- hadoop数据存放目录,修改为用户目录下不存在的目录-->

<name>hadoop.tmp.dir</name>

<value>/home/data/hadoop</value>

</property>

保存退出。

  4.2进入hadoop安装目录,如果是第一次启动,需要先格式化namenode(注意,namenode只能格式化一次,在bin目录下执行)

cd ..

  退回到Hadoop目录下

cd ..

  格式化namenode

bin/hdfs namenode -format

4.3在sbin目录下启动HDFS。

sbin/start-dfs.sh

  查看进程

jps

4.4等待启动完成后,就可以配置yarn了,在配置之前先去浏览器页面检查HDFS是否启动成功,输入namenode的ip+端口号50070。实验中操作机1 的IP为:90.10.10.42(以实验IP为准)。

输入URL:90.10.10.42:50070

出现这个页面代表hdfs安装成功。

步骤5:配置yarn并验证

  5.1进入配置目录etc/hadoop/,查看mapred配置文件,发现没有mapred-site.xml。

  进入安装目录

cd etc/hadoop

  查看

ls

  显示当前路径

pwd

5.2复制配置文件并命名为mapred-site.xml,然后修改配置文件。

cp mapred-site.xml.template mapred-site.xml

vim mapred-site.xml

  添加内容:

<property>

<name>mapreduce.framework.name</name>

<value>yarn</value>

</property>

 5.3修改yarn-site.xml的配置内容。

vim yarn-site.xml

  添加内容:

<!-- 指定mapreduce的shuffle-->

<property>

<name>yarn.nodemanager.aux-services</name>

<value>mapreduce_shuffle</value>

</property>

<!-- 指定resourcemanager的ip地址-->

<property>

<name>yarn.resourcemanager.hostname</name>

<value>standalone</value>

</property>

5.4启动yarn。

  进入Hadoop安装目录

cd ../..

  sbin目录下启动yarn命令

sbin/start-yarn.sh

5.5等待启动完成后,就可以去浏览器页面检查是否启动成功,输入刚刚节点的ip:8088,实验中操作机1 的IP为:90.10.10.42。

输入URL:90.10.10.42:8088

出现这个界面代表yarn启动成功。

吴裕雄--天生自然HADOOP操作实验学习笔记:单节点伪分布式安装的更多相关文章

  1. 吴裕雄--天生自然HADOOP操作实验学习笔记:hbase学生选课案例

    实验目的 复习hbase的shell操作和javaAPI操作 了解javaWeb项目的MVC设计 学会dao(数据库访问对象)和service层的代码编写规范 学会设计hbase表格 实验原理 前面我 ...

  2. 吴裕雄--天生自然HADOOP操作实验学习笔记:hbase的javaAPI应用

    实验目的 进一步了解hbase的操作 熟悉使用IDEA进行java开发 熟悉hbase的javaAPI 实验原理 前面已经了解通过hbase的shell操作hbase,确实比较难以使用,另外通过hiv ...

  3. 吴裕雄--天生自然HADOOP操作实验学习笔记:mapreduce和yarn命令

    实验目的 了解集群运行的原理 学习mapred和yarn脚本原理 学习使用Hadoop命令提交mapreduce程序 学习对mapred.yarn脚本进行基本操作 实验原理 1.hadoop的shel ...

  4. 吴裕雄--天生自然HADOOP操作实验学习笔记:pig简介

    实验目的 了解pig的该概念和原理 了解pig的思想和用途 了解pig与hadoop的关系 实验原理 1.Pig 相比Java的MapReduce API,Pig为大型数据集的处理提供了更高层次的抽象 ...

  5. 吴裕雄--天生自然HADOOP操作实验学习笔记:安装zookeeper集群

    实验目的 了解zookeeper的概念和原理 学会安装zookeeper集群并验证 掌握zookeeper命令使用 实验原理 1.Zookeeper介绍 ZooKeeper是一个分布式的,开放源码的分 ...

  6. 吴裕雄--天生自然HADOOP操作实验学习笔记:hbase微博案例

    实验目的 熟悉hbase表格设计的方法 熟悉hbase的javaAPI 通过API理解掌握hbase的数据的逻辑视图 了解MVC的服务端设计方式 实验原理 上次我们已经初步设计了学生选课案例的,具体功 ...

  7. 吴裕雄--天生自然HADOOP操作实验学习笔记:使用hive操作hbase

    实验目的 熟悉hive和hbase的操作 熟悉hadoop.hbase.hive.zookeeper的关系 熟练大数据环境的搭建 学会分析日志排除问题 实验原理 1.hive整合hbase原理 前面大 ...

  8. 吴裕雄--天生自然HADOOP操作实验学习笔记:mapreduce代码编程

    实验目的 深入了解mapreduce的底层 了解IDEA的使用 学会通过本地和集群环境提交程序 实验原理 1.回忆mapreduce模型 前面进行了很多基础工作,本次实验是使用mapreduce的AP ...

  9. 吴裕雄--天生自然HADOOP操作实验学习笔记:分布式及RPC通信简介

    实验目的 掌握GOF设计模式的代理模式 了解掌握socket编程.java反射.动态代理 了解NIO.多线程 掌握hadoop的RPC框架使用API 实验原理 1.什么是RPC 在hadoop出现以前 ...

随机推荐

  1. 7 scrapy 初识

    scrapy框架 框架介绍: Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架,非常出名,非常强悍.所谓的框架就是一个已经被集成了各种功能(高性能异步下载,队列,分布式,解析,持久化 ...

  2. java中4种常用线程池

    一.线程池 线程池:说白了,就是一种线程使用模式.线程过多会带来调度开销,进而影响整体性能.而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务,这避免了在处理短时间任务时创建与销毁线程的代价 ...

  3. python setattr()、getattr()、hasattr() 函数用法介绍

    一.函数介绍 在动态检查对象是否包含某些属性(包括方法〉相关的函数有如下几个: hasattr(object,name):检查 object 对象是否包含名为 name 的属性或方法. getattr ...

  4. flask_migrate

    flask_migrate 1.      flask_migrate doc: https://flask-migrate.readthedocs.io/en/latest/ 1.1.    简介 ...

  5. 寒假pta一

    打印沙漏 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输出奇数个符号:各行符号中心对齐 ...

  6. Nexus-vPC相关特性

    vPC Peer-switch: 不开启这功能,只有Primary设备发送BPDU,开启之后,将会把这一对设备呈现为一个STP Root,使用一个MAC地址,那么都可以发送BPDU了.STP BPDU ...

  7. Spring AOP 中 advice 的四种类型 before after throwing advice around

    spring  AOP(Aspect-oriented programming) 是用于切面编程,简单的来说:AOP相当于一个拦截器,去拦截一些处理,例如:当一个方法执行的时候,Spring 能够拦截 ...

  8. [经验] 如何将 Java 项目发布到云服务器上并可以访问

    环境: 云服务器 Linux centos7.6 1: 安装 Tomcat  (apache-tomcat-9.0.26.tar.gz) 下载压缩包 --> 通过SSH上传到云服务器 --> ...

  9. python 顺序执行任务

    #!/usr/bin/python import os import time start_command="sh start-etl.sh " es_mac_confPath = ...

  10. idea提示非法字符

    问题: 解决方法: 将编码格式UTF-8+BOM文件转为普通的UTF-8文件. 一.简单方法,在AS右下角,将编码改为GBK,再转为UTF-8,可以解决. 二.可以用EditPlus 1.将文件用Ed ...