码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Hadoop】Hadoop 调优


    本文介绍常用调优手段,面试重点。

    1.数据压缩

    优点:节约磁盘空间、减少网络数据传输、减少 I/O 操作,从而提高 MR 程序的运行速度。

    缺点:增加压缩和解压操作,增加了 CPU 运算负担。

    原则:运算密集型 job 少用,I/O 密集型 job 多用。

    格式:DEFLATE、Gzip、bzip2、LZO,Snappy

    2.小文件优化

    2.1 小文件弊端

    每个文件都要在 NameNode 上创建对应的元数据,这个元数据的大小约为 150byte,这样当小文件比较多的时候,就会产生很多的元数据文件,一方面会大量占用 NameNode 的内存空间,另一方面就是元数据文件过多,使得寻址索引速度变慢。

    小文件过多,在进行 MR 计算时,会生成过多切片,需要启动过多的 MapTask。每个 MapTask 处理的数据量小,导致 MapTask 的处理时间比启动时间还小,白白消耗资源。

    2.2 解决

    1. 在数据采集的时候,就将小文件或小批数据合成大文件再上传 HDFS。
      • Hadoop Archive 是一个高效的将小文件放入 HDFS 块中的文件存档工具,能够将多个小文件打包成一个 HAR 文件,从而达到减少 NameNode 的内存使用。
    2. 在业务处理之前,在 HDFS 上使用 MapReduce 程序对小文件进行合并。
      • SequenceFile 是由一系列的二进制 k/v 组成,如果为 key 为文件名,value 为文件内容,可将大批小文件合并成一个大文件。
    3. 在 MapReduce 处理时,可采用 CombineTextInputFormat 提高效率。
      • CombineTextInputFormat 用于将多个小文件在切片过程中生成一个单独的切片或者少量的切片。
    4. 开启 uber 模式,实现 jvm 重用
      • 默认情况下,每个 Task 任务都需要启动一个 jvm 来运行,如果 Task 任务计算的数据量很小,我们可以让同一个 Job 的多个 Task 运行在一个 Jvm 中,不必为每个 Task 都开启一个 Jvm.
  • 相关阅读:
    maven打包时,如何构建docker镜像,并推送到私有docker仓库
    python神经网络编程 代码,python神经网络编程 豆瓣
    【DETR】
    支持中文!秒建 wiki 知识库的开源项目,构建私人知识网络
    TP5 中 FIND_IN_SET的使用方法 精准匹配,字段值以“,”隔开查询
    CocosCreator接入wwise的CocosAndroid.mk
    WEB网页设计期末作业个人主页——基于HTML+CSS制作个人简介网站
    初识HTML超文本标记语言
    TypeError: RedLock is not a constructor.
    onnx删除无用属性
  • 原文地址:https://blog.csdn.net/weixin_45545090/article/details/126083139
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号