hoelog created HDFS-7539:
----------------------------
Summary: Namenode can't leave safemode because of Datanodes' IPC
socket timeout
Key: HDFS-7539
URL: https://issues.apache.org/jira/browse/HDFS-7539
Project: Hadoop HDFS
Issue Type: Bug
Components: datanode, namenode
Affects Versions: 2.5.1
Environment: 1 master, 1 secondary and 128 slaves, each node has x24
cores, 48GB memory. fsimage is 4GB.
Reporter: hoelog
During the starting of namenode, data nodes seem waiting namenode's response
through IPC to register block pools.
here is DN's log -
2014-12-16 20:28:09,064 INFO org.apache.hadoop.hdfs.server.datanode.DataNode:
Acknowledging ACTIVE Namenode Block pool
BP-877672386-10.114.130.143-1412666752827 (Datanode Uuid
2117395f-e034-4b4a-adec-8a28464f4796) service to NN.x.com/10.x.x143:9000
But namenode is too busy to responde it, and datanodes occur socket timeout -
default is 1 minute.
2014-12-16 20:29:09,857 WARN org.apache.hadoop.hdfs.server.datanode.DataNode:
IOException in offerService
java.net.SocketTimeoutException: Call From DN1.x.com/10.x.x.84 to NN.x.com:9000
failed on socket timeout exception: java.net.SocketTimeoutException: 60000
millis timeout while waiting for channel to be ready for read. ch :
java.nio.channels.SocketChannel[connected local=/10.x.x.84:57924
remote=NN.x.com/10.x.x.143:9000]; For more details see:
http://wiki.apache.org/hadoop/SocketTimeout
same events repeat and eventually NN drops most connecting trials from DN. So
NN can't leave safemode.
DN's log -
2014-12-16 20:32:25,895 WARN org.apache.hadoop.hdfs.server.datanode.DataNode:
IOException in offerService
java.io.IOException: failed on local exception java.io.ioexception connection
reset by peer
There is no troubles in the network, configuration or servers. I think NN is
too busy to respond to DN in a minute.
I configured "ipc.ping.interval" to 15 mins In the core-site.xml, and that was
helpful for my cluster.
<property>
<name>ipc.ping.interval</name>
<value>900000</value>
</property>
In my cluster, namenode responded 1 min ~ 5 mins for the DNs' request.
It will be helpful if there is more elegant solution.
2014-12-16 23:28:16,598 INFO org.apache.hadoop.hdfs.server.datanode.DataNode:
Acknowledging ACTIVE Namenode Block pool BP-877672386-10.x.x.143-1412666752827
(Datanode Uuid c4f7beea-b8e9-404f-bc81-6e87e37263d2) service to
NN/10.x.x.143:9000
2014-12-16 23:31:32,026 INFO org.apache.hadoop.hdfs.server.datanode.DataNode:
Sent 1 blockreports 2090961 blocks total. Took 1690 msec to generate and 193738
msecs for RPC and NN processing. Got back commands
org.apache.hadoop.hdfs.server.protocol.FinalizeCommand@20e68e11
2014-12-16 23:31:32,026 INFO org.apache.hadoop.hdfs.server.datanode.DataNode:
Got finalize command for block pool BP-877672386-10.x.x.143-1412666752827
2014-12-16 23:31:32,032 INFO org.apache.hadoop.util.GSet: Computing capacity
for map BlockMap
2014-12-16 23:31:32,032 INFO org.apache.hadoop.util.GSet: VM type = 64-bit
2014-12-16 23:31:32,044 INFO org.apache.hadoop.util.GSet: 0.5% max memory 3.6
GB = 18.2 MB
2014-12-16 23:31:32,045 INFO org.apache.hadoop.util.GSet: capacity = 2^21
= 2097152 entries
2014-12-16 23:31:32,046 INFO
org.apache.hadoop.hdfs.server.datanode.BlockPoolSliceScanner: Periodic Block
Verification Scanner initialized with interval 504 hours for block pool
BP-877672386-10.114.130.143-1412666752827
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)