上图给出了最终会调用到complete RPC的客户端侧方法链路(除去Router那条线了)。
org.apache.hadoop.hdfs.DFSOutputStream#completeFile(org.apache.hadoop.hdfs.protocol.ExtendedBlock):文章来源:https://www.toymoban.com/news/detail-635589.html
下面这个方法在complete rpc返回true之前,会进行重试,直到超过最大重试次数抛异常。
另外需要注意的是,这个方法在锁里(锁的是当前的流对象)。文章来源地址https://www.toymoban.com/news/detail-635589.html
// should be called holding (this) lock since setTestFilename() may
// be called during unit tests
protected void completeFile(ExtendedBlock last) throws IOException
到了这里,关于【HDFS】每天一个RPC系列----complete(二):客户端侧的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!