Hadoop常见错误和处理方式

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介:

常见问题及处理

  • mysql版本,必须是MYSQL5.1。

查询办法mysqladmin version

在建立hive数据库的时候,最好是:create database hive;

oozie的数据库,同样:create database oozie;

hadoop采集的字符集问题。

修改/etc/sysconfig/i18n 更改字符集为en_US.UTF-8

重启机器生效。

重启机器的指令为:在root下敲入如下指令:sync;sync;init 6

修改mapreduce。

在gateway/性能下修改:MapReduce 子 Java 基础选项 、Map 任务 Java 选项库 、Reduce 任务 Java 选项库 全部配置成 -Xmx4294967296

在TASKTRACKER/性能下修改:MapReduce 子 Java 基础选项 、Map 任务 Java 选项库 、Reduce 任务 Java 选项库 全部配置成 -Xmx4294967296

必须关注各个任务的详细情况

当出现如下的错误的时候,请及时的将下载的进程数调小。

 
  1. vi /home/boco/oozie_wy/config/lte/mro/ftp/807101.xml 将max_thread由原来的6个调整为3个,或者协调厂家加大FTP的最大线程数。 
  2. stderr logs: 
  3. org.apache.commons.net.ftp.FTPConnectionClosedException: FTP response 421 received. Server closed connection
  4. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:363) 
  5. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:290) 
  6. at org.apache.commons.net.ftp.FTP.connectAction(FTP.java:396) 
  7. at org.apache.commons.net.ftp.FTPClient.connectAction(FTPClient.java:796) 
  8. at org.apache.commons.net.SocketClient.connect(SocketClient.java:172) 
  9. at org.apache.commons.net.SocketClient.connect(SocketClient.java:192) 
  10. at org.apache.commons.net.SocketClient.connect(SocketClient.java:285) 
  11. at com.boco.wangyou.utils.Ftp.connectServer(Ftp.java:550) 
  12. at com.boco.wangyou.lte.mro.ftp.tools.FindFileThread.run(FindFileThread.java:67) 
  13. 登录ftp服务器【10.140.177.149】失败,FTP服务器无法打开! 
  14. org.apache.commons.net.ftp.FTPConnectionClosedException: FTP response 421 received. Server closed connection
  15. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:363) 
  16. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:290) 
  17. at org.apache.commons.net.ftp.FTP.connectAction(FTP.java:396) 
  18. at org.apache.commons.net.ftp.FTPClient.connectAction(FTPClient.java:796) 
  19. at org.apache.commons.net.SocketClient.connect(SocketClient.java:172) 
  20. at org.apache.commons.net.SocketClient.connect(SocketClient.java:192) 
  21. at org.apache.commons.net.SocketClient.connect(SocketClient.java:285) 
  22. at com.boco.wangyou.utils.Ftp.connectServer(Ftp.java:550) 
  23. at com.boco.wangyou.lte.mro.ftp.tools.FindFileThread.run(FindFileThread.java:67) 
  24. 登录ftp服务器【10.140.177.149】失败,FTP服务器无法打开! 
  25. org.apache.commons.net.ftp.FTPConnectionClosedException: FTP response 421 received. Server closed connection
  26. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:363) 
  27. at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:290) 
  28. at org.apache.commons.net.ftp.FTP.connectAction(FTP.java:396) 
  29. at org.apache.commons.net.ftp.FTPClient.connectAction(FTPClient.java:796) 
  30. at org.apache.commons.net.SocketClient.connect(SocketClient.java:172) 
  31. at org.apache.commons.net.SocketClient.connect(SocketClient.java:192) 
  • TASKTRACKER和HDFS组的问题

发现部分地方在安装的时候,将所有的机器分组的问题。

如果分组,需要将每个组的参数都要修改。

目前发现很多的地方,TASKTRACKER和HDFS都分了组,但是只修改一组的参数,造成系统大量出问题。

java heap size以及tasktracker被拉黑名单的问题。

  • namenode和datanode的内存配置问题。

建议将使用的内存修改为4G左右。

  • 建议将HIVE2服务放到一个辅节点上。

hive2放到辅节点上,经常出现add_partation挂起报错。

  • 解决HIVE经常挂死的问题

修改zookeeper的最大客户端连接数,maxClientCnxns修改为3600或者修改成0不限制

自动清空时间间隔,autopurge.purgeInterval 修改为1小时

  • 厂家XML配置的问题。

如果厂家是这样的:/data/dataservice/mr/ltemro/huawei/20140815/01/362323/TD-LTE_MRO_HUAWEI_010133150144_362323_20140815011500.xml.gz

建议配置成这样的:

路径:/data/dataservice/mr/ltemro/huawei/$TIME$/$ENODEB$

时间格式:yymmdd/hh

  • 在/home/boco/oozie_wy/config/lte/mro/ftp下禁止存放.bak文件

有一个省份的mapper数超多,导致解析很长时间没有完成。

进一步发现FTP在合并文件的时候报错,再进一步发现同一个IP地址,同一个OMC启动了三个mapper进程去下载数据导致文件合并失败。

发现是修改了ftp.xml文件,没有删除原来的文件,而是以一个bak文件存放。

删除这些bak文件,mapper数量正常。

原mapper数1731个,删除之后mapper数41个,采集正常。

打开50030看FTP的日志,存在如下的报错:

 
  1. java.io.FileNotFoundException: File does not exist: /user/boco/cache/wy/ltemro/1411032293348/xml/155/2014-09-18_11/TD-LTE_MRO_ERICSSON_OMC1_303024_20140918111500.xml.zip 
  2. at org.apache.hadoop.hdfs.server.namenode.INodeFile.valueOf(INodeFile.java:39) 
  3. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocationsUpdateTimes(FSNamesystem.java:1341) 
  4. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocationsInt(FSNamesystem.java:1293) 
  5. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocations(FSNamesystem.java:1269) 
  6. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocations(FSNamesystem.java:1242) 
  7. at org.apache.hadoop.hdfs.server.namenode.NameNodeRpcServer.getBlockLocations(NameNodeRpcServer.java:392) 
  8. at org.apache.hadoop.hdfs.protocolPB.ClientNamenodeProtocolServerSideTranslatorPB.getBlockLocations(ClientNamenodeProtocolServerSideTranslatorPB.java:172) 
  9. at org.apache.hadoop.hdfs.protocol.proto.ClientNamenodeProtocolProtos$ClientNamenodeProtocol$2.callBlockingMethod(ClientNamenodeProtocolProtos.java:44938) 
  10. at org.apache.hadoop.ipc.ProtobufRpcEngine$Server$ProtoBufRpcInvoker.call(ProtobufRpcEngine.java:453) 
  11. at org.apache.hadoop.ipc.RPC$Server.call(RPC.java:1002) 
  12. at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:1701) 
  13. at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:1697) 
  14. at java.security.AccessController.doPrivileged(Native Method) 
  15. 或者: 
  16. org.apache.hadoop.ipc.RemoteException(org.apache.hadoop.hdfs.server.namenode.LeaseExpiredException):  
  17.     Lease mismatch on /user/boco/cache/wy/ltemro/1411032293348/xml/155/2014-09-18_11/TD-LTE_MRO_ERICSSON_OMC1_3030_20140918.xml owned by DFSClient_NONMAPREDUCE_ 
  18.     -1274827212_1 but is accessed by DFSClient_NONMAPREDUCE_-216613905_1 
  19. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.checkLease(FSNamesystem.java:2459) 
  20. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.checkLease(FSNamesystem.java:2437) 
  21. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.completeFileInternal(FSNamesystem.java:2503) 
  22. at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.completeFile(FSNamesystem.java:2480) 
  23. at org.apache.hadoop.hdfs.server.namenode.NameNodeRpcServer.complete(NameNodeRpcServer.java:535) 
  24. at org.apache.hadoop.hdfs.protocolPB.ClientNamenodeProtocolServerSideTranslatorPB.complete(ClientNamenodeProtocolServerSideTranslatorPB.java:337) 
  25. at org.apache.hadoop.hdfs.protocol.proto.ClientNamenodeProtocolProtos$ClientNamenodeProtocol$2.callBlockingMethod(ClientNamenodeProtocolProtos.java:44958) 
  26. at org.apache.hadoop.ipc.ProtobufRpcEngine$Server$ProtoBufRpcInvoker.call(ProtobufRpcEngine.java:453) 
  27. at org.apache.hadoop.ipc.RPC$Server.call(RPC.java:1002) 
  • REDIS故障

解析时候报错,错误如下:

 
  1. redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool 
  2. at redis.clients.util.Pool.getResource(Pool.java:22) 
  3. at com.boco.wangyou.utils.JedisUtils.getJedis(JedisUtils.java:47) 
  4. at com.boco.wangyou.utils.JedisUtils.getTableValues(JedisUtils.java:119) 
  5. at com.boco.wangyou.lte.mro.tdl.tools.LteMroXMLParser. 

此问题一般是因为REDIS没有启动导致。

  • 克隆机器安装的问题

把一个节点的第二步都装好了,把它克隆到其它主机上,再把克隆到的主机的IP

(注意在修改IP配置文件的时候,将HWaddr也改了,一般是这种格式:00:50:56:80:4E:D6,

否则在连接时会找不到硬盘)和主机名改下。

此种情况主要出现在使用vmvare vsphere克隆导致的。

注意:

克隆之后的机器要修改IP地址,主机名,MAC地址。

  • redis挂死,导致无法采集
 
  1. #现象 

redis.clients.jedis.exceptions.JedisDataException:

 
  1. MISCONF Redis is configured to save RDB snapshots, 
  2. but is currently not able to persist on disk. 

启动客户端:

 
  1. /usr/local/redis/redis-cli 

输入:

 
  1. config set stop-writes-on-bgsave-error no 
  • 主节点7180无法访问

1)检查主节点是不是日志空间满了,如果满了,需要删除/var/log/hive下面日志

2)删除浏览器的cookie访问记录

hadoop相关服务启动命令:

 
  1. sudo service cloudera-scm-server stop 
  2. sudo service cloudera-scm-server-db stop 
  3. sudo service cloudera-scm-server start 
  4. sudo service cloudera-scm-server-db start 
  • LTEMRO采集报错

主要是在这一步报错:CREATE_EXTERNAL_TABLE_NODE

有效的采样点数据,是如下的八个字段必须有值:

 
  1. MR.LteScEarfcn 主小区频点 
  2. MR.LteScPci 主小区PCI 
  3. MR.LteScRSRP 主小区的RSRP 
  4. MR.LteScRSRQ 主小区RSRQ 
  5. MR.LteNcEarfcn 邻小区频点 
  6. MR.LteNcPci 邻小区PCI 
  7. MR.LteNcRSRP 邻小区的RSRP 
  8. MR.LteNcRSRQ 邻小区RSRQ 

只要有有效数据,就不会报这个错。

  • 查看日志

HIVE的日志主要是在:/var/log/hive/

oozie的日志主要在: /var/log/oozie/

HDFS的日志主要在: /var/log/hadoop-hdfs/

zookeeper的日志主要在:/var/log/zookeeper/

在出现问题的时候,可以看看这些日志。

  • zookeeper无法启动。

处理办法:到master主机的/var/lib/zookeeper,删除所有的文件,重启zookeeper即可。

sudo mkdir version-2

sudo chown -R zookeeper:zookeeper version-2

  • loudera-manager-installer.bin安装报错。

报错如下:

 
  1. Loaded plugins: aliases, changelog, downloadonly, fastestmirror, kabi, presto, 
  2. : refresh-packagekit, security, tmprepo, verify, versionlock 
  3. Loading support for CentOS kernel ABI 
  4. Loading mirror speeds from cached hostfile 
  5. http://10.233.9.63/cdh4.3.0/cdh4.3/repodata/repomd.xml: [Errno 14] PYCURL ERROR 22 - "The requested URL returned error: 403" 
  6. Trying other mirror. 
  7. Error: Cannot retrieve repository metadata (repomd.xml) for repository: cloudera-cdh4. Please verify its path and try again 

处理办法:

删除集群中每一台机器上原有的repo文件,rm -rf /etc/yum.repos.d/*

然后修改cloudera-chd4.repo、cloudera-impala.repo和 cloudera-manager.repo文件,将文件中的地址换成主节点的地址。

将cloudera-chd4.repo、cloudera-impala.repo和 cloudera-manager.repo文件上传到集群中每一台机器的/etc/yum.repos.d/目录下。


本文作者:佚名

来源:51CTO

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
分布式计算 资源调度 Hadoop
Hadoop常见错误及解决方案、Permission denied: user=dr.who, access=WRITE, inode=“/“:summer:supergroup:drwxr-xr-x
Hadoop常见错误及解决方案、Permission denied: user=dr.who, access=WRITE, inode=“/“:summer:supergroup:drwxr-xr-x
Hadoop常见错误及解决方案、Permission denied: user=dr.who, access=WRITE, inode=“/“:summer:supergroup:drwxr-xr-x
|
分布式计算 Hadoop
hadoop初学者MapReduce常见错误
image.png 主机与ip地址的映射,不可以出错配置完后hostname一下 image.png core-site.xml 正确配置 fs.
821 0
|
分布式计算 安全 Hadoop
|
分布式计算 Java Hadoop
Hadoop-2.8.0集群搭建、hadoop源码编译和安装、host配置、ssh免密登录、hadoop配置文件中的参数配置参数总结、hadoop集群测试,安装过程中的常见错误
25. 集群搭建 25.1 HADOOP集群搭建 25.1.1集群简介 HADOOP集群具体来说包含两个集群:HDFS集群和YARN集群,两者逻辑上分离,但物理上常在一起 HDFS集群: 负责海量数据的存储,集群中的角色主要有NameNode / DataNode YARN集群: 负责海量数据运算时的资源调度,集群中的角色主要有 ResourceManager /NodeManag
4665 0
|
分布式计算 Hadoop 网络安全
Hadoop - Mac OSX下配置和启动hadoop以及常见错误解决
0. 安装JDK 参考网上教程在OSX下安装jdk   1. 下载及安装hadoop a) 下载地址: http://hadoop.apache.org   b) 配置ssh环境 在terminal里面输入: ssh localhost 如果有错误提示信息,表示当前用户没有权限。
1666 0
|
Java 容器 安全
Hadoop常见错误2
问题1:在程序的日志中看到,在reduce阶段出现了异常:Shuffle Error: Exceeded MAX_FAILED_UNIQUE_FETCHES; bailing-out ,程序里需要打开文件,系统默认为1024,也可以通过ulimit -a查看 编辑文件/etc/security/limits.
1068 0
|
分布式计算 安全 Java
Hadoop常见错误1
1 关于 Warning: $HADOOP_HOME is deprecated.   hadoop 1.0.0版本,安装完之后敲入hadoop命令时,老是提示这个警告: Warning: $HADOOP_HOME is deprecated.   经查hadoop-1.0.0/bin/hadoop脚本和"hadoop-config.sh"脚本,发现脚本中对HADOOP_HOME的环境变量设置做了判断,笔者的环境根本不需要设置HADOOP_HOME环境变量。
1108 0
|
11天前
|
存储 分布式计算 Hadoop
大数据处理架构Hadoop
【4月更文挑战第10天】Hadoop是开源的分布式计算框架,核心包括MapReduce和HDFS,用于海量数据的存储和计算。具备高可靠性、高扩展性、高效率和低成本优势,但存在低延迟访问、小文件存储和多用户写入等问题。运行模式有单机、伪分布式和分布式。NameNode管理文件系统,DataNode存储数据并处理请求。Hadoop为大数据处理提供高效可靠的解决方案。
33 2
|
11天前
|
分布式计算 Hadoop 大数据
大数据技术与Python:结合Spark和Hadoop进行分布式计算
【4月更文挑战第12天】本文介绍了大数据技术及其4V特性,阐述了Hadoop和Spark在大数据处理中的作用。Hadoop提供分布式文件系统和MapReduce,Spark则为内存计算提供快速处理能力。通过Python结合Spark和Hadoop,可在分布式环境中进行数据处理和分析。文章详细讲解了如何配置Python环境、安装Spark和Hadoop,以及使用Python编写和提交代码到集群进行计算。掌握这些技能有助于应对大数据挑战。
|
13天前
|
SQL 分布式计算 Hadoop
利用Hive与Hadoop构建大数据仓库:从零到一
【4月更文挑战第7天】本文介绍了如何使用Apache Hive与Hadoop构建大数据仓库。Hadoop的HDFS和YARN提供分布式存储和资源管理,而Hive作为基于Hadoop的数据仓库系统,通过HiveQL简化大数据查询。构建过程包括设置Hadoop集群、安装配置Hive、数据导入与管理、查询分析以及ETL与调度。大数据仓库的应用场景包括海量数据存储、离线分析、数据服务化和数据湖构建,为企业决策和创新提供支持。
51 1

热门文章

最新文章

相关实验场景

更多