运行过程的原理图解:
更多详细图解:https://www.cnblogs.com/muhongxin/p/9436765.html
过程:创建两个namenode,一个active,一个standby,client向代理(proxy)发出请求,proxy将请求发送给两个namenode,而且子节点DataNode向向两个namenode同时反馈。
两个NameNode为了数据同步,会通过一组称作JournalNodes的独立进程进行相互通信。当active状态的NameNode的命名空间有任何修改时,会告知大部分的JournalNodes进程。standby状态的NameNode有能力读取JNs中的变更信息,并且一直监控edit log的变化,把变化应用于自己的命名空间。standby可以确保在集群出错时,命名空间状态已经完全同步了
1.如何保证hdfs的高可用性:
- 现象:
因为namenode只有一个,当client访问HDFS的时候,都需要找到