一、         linux部分

  1. 请阐述swap分区作用,您认为hadoop集群中的linux是否必须有swap分区?
答:在Linux中,如果一个进程的内存空间不足,那么,它会将内存中的部分数据暂时写到磁盘上,当需要时,再将磁盘上的数据动态置换到内存中,通常而言,这种行为会大大降低进程的执行效率。在MapReduce分布式计算环境中,用户完全可以通过控制每个作业处理的数据量和每个任务运行过程中用到的各种缓冲区大小,避免使用swap分区。
  具体方法是调整/etc/sysctl.conf文件中的vm.swappiness参数。vm.swappiness有效范围是0~100,值越高表明内核应该更积极将应用程序的数据交换到磁盘,较低的值表示将延迟这种行为,而不是强制丢弃文件系统的缓冲区。

参考链接:http://www.aixchina.net/Question/172307

  1. 请根据free -g -t,说明内存使用情况,给出剩余内存和可用内存大小。

Total userd free shared buffers cached

Mem: 62 56 6 0 0 45

-/+ buffers/cache: 10   52

Swap: 19 0 19

Total: 82 56 26

答:剩余内存等于userd-buffers-cache,即-buffers/cache的值10

可用内存等于free+buffers+cache,即+buffers/cache的值52

参考链接:http://www.cnblogs.com/pengdonglin137/p/3315124.html

  1. 请说明ssh-copy-id hadoop@host命令实现的作用

答:ssh-copy-id 将本机的公钥复制到远程机器的authorized_keys文件中

  1. 写一个脚本,实现批量添加20个用户,用户名为hdfs01-20,密码为用户名后面跟5个随机字符。
 #!/bin/bash
	for i in seq 1 9
   do
   pwd=$(cat /dev/urandom | head -1 | md5sum | head -c 5)
	username=hdfs0$i
   useradd username
   echo "${username}$pwd" | passwd --stdin user$i
   echo ${username} ${username}$pwd" >> userinfo.txt
   done
   for i in seq 10 20
   do
   pwd=$(cat /dev/urandom | head -1 | md5sum | head -c 5)
   useradd hdfs$i
   echo "hdfs$i$pwd" | passwd --stdin user$i
   echo hdfs$i hdfs$i$pwd" >> userinfo.txt
   done
  1. 查看当前系统中每个IP的连接数

netstat -n |awk ‘/^tcp/ {print $5}’|awk -F: ‘{print $1}’|sort|uniq -c|sort -rn

其中uniq -c是求uv,sort -rn 是降序,以数字顺序排序

参考值:http://yuangeqingtian.blog.51cto.com/6994701/1191651

  1. 写出查找yarn-hdfs-resourcemanager-master01.log包含error(不区分大小写)字符前后各15行的命令

答案:cat yarn-hdfs-resourcemanager-master01|grep -i ‘error’-C  15

  1. 写出查找当前时间48小时之前的hdfs用户的普通文件并删除的命令。

答:find -mtime +2 -user hdfs -type f -exec rm {} \

参考自:http://www.2cto.com/os/201208/149552.html

  1. 写出显示/usr/local/nagios/etc/nrpc.cfg文件中出去以#开头和空行的所有内容的命令。

答:cat  /usr/local/nagios/etc/nrpc.cfg |grep ‘^#’

cat /usr/local/nagios/etc/nrpc.cfg |grep ‘^$’

  1. 假设有200台HADOOP主机,slave001到slave200,在开启ssh互信的情况下,编写脚本实现在任意主机上执行批量查看磁盘大小的功能

期望结果:

Slave001:

/dev/sdb1 ext4 548G 224G 297G 43% /data/disk01s

Slave002:

/dev/sdb1 ext4 548G 224G 297G 43% /data/disk01s

Slave003:

...

答:

vim ssh_cmd.sh

#!/bin/bash

cmd=$1

for((i=1;i<=200;i++))

do

a=$((1000+$i))

user=Slave${a:1}

echo ${user}:

ssh ${user}

out=cmd

echo ${out}

done

sh  ssh_cmd.sh `df -h /dev/sdb1`

二、HADOOP部分

  1. Hadoop自身具有严格的权限管理和安全措施保证集群正常运行。(F)
  2. NameNode负责管理metadata,client端每次读写请求,它都会从磁盘中读取或者写入metadata信息并反馈client端。(F)
  3. Hadoop2.0以上版本支持热部署,修改fair-scheduler.xml或capacity-scheduler.xml文件,调度策略自动生效。(F)
  4. HDFS文件支持随机读写。(F)
  5. Hadoop默认调度器为公平调度,队列内部是FIFO策略。(F)
  6. 不同版本hadoop集群之间数据迁移如何实现(给出两种实现方法)

答:1.使用distcp命令,例如hadoop distcp hftp://10.4.2.41:50070/user  hdfs://nn2:8020/bar/foo

参考自:http://www.tuicool.com/articles/INJZVfY

2.小数据量hadoop -get拷贝到本地,在scp到新集群

  1. 用什么命令查看hadoop相关进程的详细情况

答:jps

  1. 如何查看集群中的job的状态,如何杀掉指定用户的所有job(命令行),写出命令。

答:

mapreduce(yarn-core)web界面查看job详细

for i in `hadoop job -list | grep -w  username| awk '{print $1}' | grep job_`;

do

hadoop job -kill $i;

done

  1. 如何给用户限制使用HDFS文件系统的大小,如限制用户hadoop大小为10T,写出命令。

答:

10.如何统计某一HDFS目录下的文件数

答:hadoop fs -ls /tmp |wc -l

11.如何快速定位某个hadoop进程的输出日志。

答:Hadoop 2.x中YARN系统的服务日志包括ResourceManager日志和各个NodeManager日志,他们的日志位置如下:
ResourceManager日志存放位置是Hadoop安装目录下的logs目录下的yarn-*-resourcemanager-*.log
NodeManager日志存放位置是各个NodeManager节点上hadoop安装目录下的logs目录下的yarn-*-nodemanager-*.log
应用程序日志包括jobhistory日志和Container日志,其中,jobhistory日志是应用程序运行日志,包括应用程序启动时间、结束时间,每个任务的启动时间、结束时间,各种counter信息等。
Container日志包含ApplicationMaster日志和普通Task日志,它们均存放在Hadoop安装目录下的userlogs目录中的application_xxx目录下,其中ApplicationMaster日志目录名称为container_xxx_000001,普通task日志目录名称则为container_xxx_000002,container_xxx_000003,….,同Hadoop 1.x一样,每个目录下包含三个日志文件:stdout、stderr和syslog,且具体含义是一样的。

12.列出您使用过的hadoop常用命令和集群管理工具。

13.列出您运维或部署过的Hadoop生态圈相关的组件

14.写出你做过的hadoop集群优化措施以及收到的效果

15.谈谈您对mapreduce和spark的看法

hadoop面试时的一些问题解答的更多相关文章

  1. hadoop面试时可能遇到的问题

    面试hadoop可能被问到的问题,你能回答出几个 ? 1.hadoop运行的原理? 2.mapreduce的原理? 3.HDFS存储的机制? 4.举一个简单的例子说明mapreduce是怎么来运行的 ...

  2. hadoop面试100道收集(带答案)

    1.列出安装Hadoop流程步骤 a) 创建hadoop账号 b) 更改ip c) 安装Java 更改/etc/profile 配置环境变量 d) 修改host文件域名 e) 安装ssh 配置无密码登 ...

  3. 面试时遇到的SQL

    CustomerID DateTime ProductName Price C001 2014-11-20 16:02:59 123 PVC 100 C001 2014-11-19 16:02:59 ...

  4. (Java后端 Java web)面试时如何展示自己非技术方面的能力(其实就是综合能力)

    这篇文章的适用范围其实不仅限于Java后端或Java Web,不过其中有些是拿这方面举例的,在其它方面,大家可以举一反三,应该也能得到些启示. 我们在面试时,会发现有些候选人技术不错,比如在Java ...

  5. 面试时,当你有权提问时,别客气,这是个逆转的好机会(内容摘自Java Web轻量级开发面试教程)

    前些天,我在博客园里写了篇文章,如何在面试中介绍自己的项目经验,收获了2千多个点击,这无疑鼓舞了我继续分享的热情,今天我来分享另外一个面试中的甚至可以帮助大家逆转的技巧,本文来是从 java web轻 ...

  6. 通过软引用和弱引用提升JVM内存使用性能的方法(面试时找机会说出,一定能提升成功率)

    初学者或初级程序员在面试时如果能证明自己具有分析内存用量和内存调优的能力,这相当有利,因为这是针对5年左右相关经验的高级程序员的要求.而对于高级程序员来说,如果能在面试时让面试官感觉你确实做过内存调优 ...

  7. 面试时怎样回答:你对原生ajax的理解

    很多人跟我一样用习惯了jq封装好的$.ajax,但是面试时,原生ajax是很多面试官喜欢问的问题,今天再查资料,打算好好整理一下自己理解的原生ajax. 首先,jq的ajax:一般我常用的参数就是这些 ...

  8. hadoop启动时,报ssh: Could not resolve hostname xxx: Name or service not known

    本文转载自:http://blog.csdn.net/wodewutai17quiet/article/details/76795951 问题:hadoop启动时,报ssh: Could not re ...

  9. 反省在北京某S2B2C电商小型公司面试时掉链子的问题

    昨天,参与北京一家公司面试时,不知道为什么,错了很多题,这些题在该家公司之前已经被问很多次了,当天精神恍惚的没答上来或答错,被问到数据库优化和乐观锁的问题,首先我谈到了存储引擎底层的数据结构 B树/B ...

随机推荐

  1. C++(MFC)中WebBrowser去除3D边框的方法(实现IDocHostUIHandler接口)控制 WebBrowser 控件的外观和行为

    在 CSDN 上经常看到以下两个问题:1.在 MFC 应用程序中,如果创建了一个 WebBrowser 控件(包括 CHtmlView 在内),如何可以把该控件的三维边框禁止掉?2.在 MFC 应用程 ...

  2. iOS 发送Email

    第一步:在程序中添加MessageUi.framework框架 第二步:引入#import <MessageUI/MessageUI.h>头文件 第三步:代码实现 3.1判断是否可以发送邮 ...

  3. Remoting创建远程对象的一个实例:

    private static Lazy<IChannelManager>  channelManager=new Lazy<IChannelManager>(() =>  ...

  4. oracle中,拼接的字符串给游标赋值

    直接open cur from sql;即可. 例子: create or replace procedure test(tableName varchar2) is TYPE cur_type IS ...

  5. perl小记

    perl是一种运行式脚本,所以在debug的时候,多用print,在后台看有没有输出相关的结果,来判断相应的错误. 部分perl正则表达式: $gene =~/^LOC/  以“LOC”开头的字符串 ...

  6. SD-WAN技术分析

    1.概述 转载须注明来自 SDNLAB并附上本文链接. 本文链接:http://www.sdnlab.com/17810.html 宽带接入以及Internet骨干网容量的持续提升,促使企业WAN技术 ...

  7. Uber从Postgres切换到MySQL

    Uber工程师在官方博客上描述了他们为什么要从 Postgres 切换到 MySQL 数据库.Uber的早期架构是由 Python编写的后端应用构成,使用了 Postgres 数据库.但此后,Uber ...

  8. js原型

    1.js基本类型和对象类型 js的简单类型包括数字(其中NaN为数字类型).字符串(类似'A'为字符,js没字符类型).布尔值.null值和undefined值.其他所有的值都是对象.数字.字符串和布 ...

  9. Mac上Homebrew的使用 (Homebrew 使 OS X 更完整)

    0 Homebrew是啥? “Homebrew installs the stuff you need that Apple didn’t.——Homebrew 使 OS X 更完整”. Homebr ...

  10. Wall--POJ1113(极角排序+求凸包)

    http://poj.org/problem?id=1113 题目大意:现在要给n个点,让你修一个围墙把这些点围起来,距离最小是l 分析  :现在就是求凸包的周长然后再加上一个圆的周长 #includ ...