栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 数据挖掘与分析

Hadoop之生产调优(五)

Hadoop之生产调优(五)

HDFS故障排除 1. NameNode 故障处理
  1. 需求:

    NameNode 进程挂了并且存储的数据也丢失了,如何恢复 NameNode

  2. 故障模拟

    • kill -9 NameNode 进程
    • 删除 NameNode 存储的数据:
      [codecat@hadoop102 dfs]$ rm -rf /opt/module/hadoop-3.1.3/data/dfs/name/*
      
  3. 解决方式

    1. 拷贝 SecondaryNameNode 中数据到原 NameNode 存储数据目录
      [codecat@hadoop102 current]$ scp -r codecat@hadoop104:/opt/module/hadoop-3.1.3/data/dfs/namesecondary/* ./name/
      
    2. 重新启动 NameNode
      [codecat@hadoop102 current]$ hdfs --daemon start namenode
      
2. 集群安全模式&磁盘修复 2.1 安全模式

文件系统只接受读数据请求,而不接受删除、修改等变更请求

2.2 进入安全模式场景
  1. NameNode 在加载镜像文件和编辑日志期间处于安全模式
  2. NameNode 再接收 DataNode 注册时,处于安全模式
2.3 退出安全模式条件
  1. dfs.namenode.safemode.min.datanodes:最小可用 datanode 数量,默认 0
  2. dfs.namenode.safemode.threshold-pct:副本数达到最小要求的 block 占系统总 block 数的百分比,默认 0.999f。(只允许丢一个块)
  3. dfs.namenode.safemode.extension:稳定时间,默认值 30000ms,即 30s
2.4 基本语法
  • 查看安全模式状态:hdfs dfsadmin -safemode get
  • 进入安全模式状态:hdfs dfsadmin -safemode enter
  • 离开安全模式状态:hdfs dfsadmin -safemode leave
  • 等待安全模式状态:hdfs dfsadmin -safemode wait
2.5 案例分析 2.5.1 启动集群进入安全模式

集群启动后,立即来到集群上删除数据,提示集群处于安全模式

2.5.2 磁盘修复

数据块损坏,进入安全模式,如何处理

  1. 分别在hadoop102,hadoop103,hadoop104统一删除某2个块信息

    [codecat@hadoop102 subdir0]$ pwd
    /opt/module/hadoop-3.1.3/data/dfs/data/current/BP-349834019-192.168.150.102-1629042571631/current/finalized/subdir0/subdir0
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741826_1002.meta 
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741834_1010.meta 
    
    [codecat@hadoop103 subdir0]$ pwd
    /opt/module/hadoop-3.1.3/data/dfs/data/current/BP-349834019-192.168.150.102-1629042571631/current/finalized/subdir0/subdir0
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741826_1002.meta 
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741834_1010.meta 
    
    [codecat@hadoop104 subdir0]$ pwd
    /opt/module/hadoop-3.1.3/data/dfs/data/current/BP-349834019-192.168.150.102-1629042571631/current/finalized/subdir0/subdir0
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741826_1002.meta 
    [codecat@hadoop102 subdir0]$ rm -rf blk_1073741834_1010.meta 
    
  2. 重新启动集群
    发现安全模式已经打开,块的数量没有达到要求。

  3. 离开安全模式

    [codecat@hadoop102 subdir0]$ hdfs dfsadmin -safemode leave
    
  4. 将元数据删除

  5. 集群恢复正常

2.5.3 模拟等待安全模式

模拟等待安全模式

  1. 查看当前模式
    [codecat@hadoop102 subdir0]$ hdfs dfsadmin -safemode get
    Safe mode is OFF
    
  2. 先进入安全模式
    [codecat@hadoop102 subdir0]$ hdfs dfsadmin -safemode enter
    Safe mode is ON
    
  3. 创建并执行下面的脚本
    [codecat@hadoop102 hadoop-3.1.3]$ vim safamode.sh
    
    #!/bin/bash
    hdfs dfsadmin -safemode wait
    hadoop fs -put /opt/module/hadoop-3.1.3/NOTICE.txt /
    
    [codecat@hadoop102 hadoop-3.1.3]$ chmod 777 safamode.sh
    [codecat@hadoop102 hadoop-3.1.3]$ ./safamode.sh 
    
  4. 再打开一个窗口,执行
    [codecat@hadoop102 hadoop-3.1.3]$ hdfs dfsadmin -safemode get
    Safe mode is OFF
    
  5. HDFS 集群上已经有上传的数据了
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/278798.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号