大数据开发面试(一)
1、Kafka 和 Flume 的应用场景?
Kafka 和 Flume 的应用场景如下:
-
Kafka:定位消息队列,适用于多个生产者和消费者共享一个主题队列的场景。适用于需要高吞吐量、可扩展性和容错能力的场景。主要用于大数据处理、实时数据流分析和日志收集等场景。
-
Flume:定位数据传输,主要用于将数据从源头传输到目标存储系统。适用于需要将大量数据发送到 HDFS、HBase 等存储系统的场景。具有较强的可靠性、可扩展性和集成 Hadoop 安全特性的特点。
总之,Kafka 更适合用于消息处理和实时数据流分析场景,而 Flume 更适合用于大数据传输和数据存储场景。根据实际需求选择合适的技术。
2、LightGBM和XGBoost的使用场景有什么不一样?
LightGBM和XGBoost都是梯度提升框架,但它们的使用场景有所不同。
XGBoost在处理数据时,采用level-wise的分裂策略,对每一层所有节点进行无差别分裂,这可能导致一些节点的增益非常小,对结果影响不大,但XGBoost也会进行分裂,带来不必要的开销。因此,XGBoost更适用于处理大规模数据集,尤其是那些需要复杂计算和内存占用量较大的情况。
LightGBM则采用了leaf-wise的分裂策略,在当前所有叶子节点中选择分裂收益最大的节点进行分裂,这种策略更容易陷入过拟合,因此需要限制最大深度以避免过拟合。然而,LightGBM的优势在于其更快的训练速度和更好的数据处理能力。它通过采用基于直方图的方法进行特征离散化和数据划分,显著减少了计算复杂度和内存占用。当处理大规模数据集时,这种优势尤其明显。此外,当数据集存在大量的稀疏特征时,LightGBM可以更好地处理,因为它使用了稀疏特征优化算法。因此,LightGBM更适合处理大规模稀疏数据集和高维稀疏数据处理。
综上所述,LightGBM和XGBoost各有其优点和使用场景。XGBoost更适合处理大规模数据集,而LightGBM则更适合处理大规模稀疏数据集和高维稀疏数据处理。在实际应用中,用户可以根据自己的数据特点选择合适的模型。
3、做ETL的时候遇到数据倾斜怎么处理?小文件呢?
数据倾斜是指在ETL(Extract-Transform-Load)过程中,数据分布不均匀,导致某些节点处理数据量过大,而其他节点处理数据量较小的情况。处理数据倾斜的方法主要有以下几种:
-
采样:对于倾斜的数据集进行采样,使得数据集分布更加均匀。
-
数据分区:将数据按照某个字段进行分区,从而减少每个分区的数据量,减轻数据处理压力。
-
增加资源:为处理倾斜数据的节点增加资源,如CPU、内存等,以提高数据处理速度。
-
使用分布式计算框架:使用分布式计算框架,如Spark、Hadoop等,将数据处理任务分配到多个节点上,提高数据处理效率。
-
数据预处理:在ETL之前,对数据进行预处理,如数据清洗、数据合并等,减少数据倾斜的发生。
-
使用专用算法:针对数据倾斜的问题,可以尝试使用一些专用算法,如MapReduce、Spark等,提高数据处理效率。
-
调整参数:调整ETL过程中的参数,如并发度、缓冲区大小等,以提高数据处理效率。
在做ETL(Extract-Transform-Load,数据提取、转换和加载)时,如果出现大量小文件,可以考虑以下几种处理方法:
-
合并小文件:使用Linux命令(如
cat、grep、awk等)或Python脚本将小文件合并成一个或多个大文件。 -
压缩小文件:使用压缩工具(如
gzip、bzip2等)将小文件压缩成一个或多个压缩文件。 -
使用分布式文件系统:使用Hadoop、Spark等分布式文件系统来处理大量小文件,提高处理效率。
-
优化数据处理流程:调整ETL流程,减少产生小文件的情况,例如在数据提取阶段就尽量减少小文件的产生。
-
使用专门的ETL工具:使用专门针对大量小文件的ETL工具,如
Apache NiFi、Talend等。
需要注意的是,具体处理方法需要根据实际需求和场景进行选择和调整。
4、已知成绩表和学生表,查询各科成绩前三名的记录?排序相关的窗口函数除了rank还有什么?
假设成绩表名为score_table,学生表名为student_table,学生表中有student_id,姓名,科目,成绩等字段,成绩表中有score_id,student_id,科目,成绩等字段。
SQL查询各科成绩前三名的记录可以这样写:
SELECTstudent_table.student_id,student_table.姓名,score_table.科目,score_table.成绩
FROMscore_table
INNER JOINstudent_table
ONscore_table.student_id = student_table.student_id
ORDER BYscore_table.成绩DESC
LIMIT3;
这个查询首先通过JOIN连接成绩表和学生表,然后按照成绩降序排序,最后取出前三名的记录。
排序相关的窗口函数除了rank,还有dense_rank、percent_rank、ntile、row_number等。这些函数都可以在窗口函数中用来对数据进行排序和分组。
5、Hive SQL优化性能的原则是什么?
Hive SQL优化性能的原则主要包括以下几点:
-
选择适当的数据存储格式:根据数据的特点和查询需求,选择适合的存储格式(如Parquet、ORC等),以提高查询性能。
-
索引和分区:在合适的列上创建索引和分区,以便快速过滤和查找数据。
-
查询优化:使用
MapJoin、ReduceJoin、Filter等查询优化技术,减少数据传输和计算量。 -
分桶和聚合:在需要统计或聚合的列上使用分桶,提高数据处理的效率。
-
数据压缩:对数据进行压缩,降低存储和传输成本。
-
参数化查询:使用参数化查询,避免重复计算相同的查询。
-
查询计划:分析查询计划,找出性能瓶颈,并进行相应的优化。
-
数据仓库和数据湖:根据业务需求,合理划分数据仓库和数据湖,实现数据的有序存储和管理。
-
异构计算:利用多核CPU、GPU等硬件资源,提高计算性能。
-
监控和调优:定期监控Hive SQL的性能,根据监控结果进行调优。
相关文章:
大数据开发面试(一)
1、Kafka 和 Flume 的应用场景? Kafka 和 Flume 的应用场景如下: Kafka:定位消息队列,适用于多个生产者和消费者共享一个主题队列的场景。适用于需要高吞吐量、可扩展性和容错能力的场景。主要用于大数据处理、实时数据流分析和日…...
softmax的高效CUDA编程和oneflow实现初步解析
本文参考了添加链接描述,其中oneflow实现softmax的CUDA编程源代码参考链接添加链接描述 关于softmax的解读以及CUDA代码实现可以参考本人之前编写的几篇文章添加链接描述,添加链接描述,添加链接描述 下面这个图片是之前本人实现的softmax.cu经过接入python接口,最终和pytor…...
如何解决 Node.js 20 升级中未预期的请求问题
在 Tubi,我们使用 Node.js 为 Web/OTT 应用进行服务端渲染及代理请求。近来,为了从新版本的性能改进和新功能中受益,我们将 Node.js 从 14.x 版本升级到了 20.x。 升级像 Node.js 这样的基础设施绝非易事,尤其是有着许多第三方依…...
no tests were found
将带有Test的方法返回类型设为void...
泛型擦除是什么
//在编译阶段使用泛型,运行阶段取消泛型,就是擦除. //因为泛型其实只是在编译器中实现的而虚拟机并不认识泛型类项,所以要在虚拟机中将泛型类型进行擦除, //擦除是将泛型以其父类代替,如String变成了object等. //在使用的时候还是进行带强制类型转化,只不过这是比较安全的转换,…...
7、线性数据结构-切片
切片slice 容器容量可变,所以长度不能定死长度可变,元素个数可变底层必须依赖数组,可以理解它依赖于顺序表,表现也像个可变容量和长度顺序表引用类型,和值类型有区别 定义切片 var s1 []int //长度、容量为0的切片&…...
linux grub2 不引导修复 grub2-install:error:/usr/lib/grub/x86_64-efi/modinfo.sh
系统部署在物理机上,开机后一直pxe不进系统,怀疑GRUB丢失。 查看bios 里 采用uefi 启动方式, 无硬盘系统引导选项, 且BMC设置为硬盘永久启动也无效。 挂载光驱ISO进入救援模式,sda为系统盘,重装grub报错 grub2-inst…...
建筑楼宇智慧能源管理系统,轻松解决能源管理问题
随着科技的进步与人们节能减排意识的不断增强,建筑楼宇是当下节能减排的重要工具。通过能源管理平台解决能效管理、降低用能成本、一体化管控、精细化管理和服务提供有力支撑。 建筑楼宇智慧能源管理系统是一种利用先进手段,采用微服务架构,…...
【洛谷算法题】P5711-闰年判断【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5711-闰年判断【入门2分支结构】🌏题目描述🌏输入格式&a…...
ArcGIS10.8 连接 PostgreSQL 及遇到的两个问题
前提 以前同事用过我的电脑连PostgreSQL,失败了。当时不知道原因,只能使用GeoServer来发布数据了。现在终于搞明白了,原因是ArcGIS10.2版本太老,无法连接PostgreSQL9.4。参考这里 为了适应时代的发展,那我就用新的Ar…...
深入跨域 - 从初识到入门 | 京东物流技术团队
前言 跨域这两个字就像一块狗皮膏药一样黏在每一个前端开发者身上,无论你在工作上或者面试中无可避免会遇到这个问题。如果在网上搜索跨域问题,会出现许许多多方案,这些方案有好有坏,但是对于阐述跨域的原理和在什么情况下需要用…...
WebSocket真实项目总结
websocket websocket是什么? websocket是一种网络通讯协议。 websocket 是HTML5开始提供的一种在单个TCP链接上进行全双工通讯的协议。 为什么需要websocket? 初次接触websocket,都会带着疑惑去学习,既然已经有了HTTP协议,为什么还需要另一…...
Python 如何实现解释器(Interpreter)设计模式?什么是解释器设计模式?
什么是解释器(Interpreter)设计模式? 解释器(Interpreter)设计模式是一种行为型设计模式,它定义了一种语言文法的表示,并提供了一个解释器,用于解释语言中的句子。该模式使得可以定…...
单片机与PLC的区别有哪些?
单片机与PLC的区别有哪些? 什么是单片机? 单片机(Microcontroller,缩写MCU)是一种集成了中央处理器(CPU)、存储器和输入/输出接口等功能模块的微型计算机系统。它通常被用于嵌入式系统和控制系统中&#x…...
修改浏览器滚动条样式--ios同款
::-webkit-scrollbar{width: 5px;height: 5px; } ::-webkit-scrollbar-thumb{border-radius: 1em;background-color: rgba(50,50,50,.3); } ::-webkit-scrollbar-track{border-radius: 1em;background-color: rgba(50,50,50,.1); } 修改滚动条样式用到的CSS伪类: :…...
python自动化测试selenium核心技术3种等待方式详解
这篇文章主要为大家介绍了python自动化测试selenium的核心技术三种等待方式示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪 UI自动化测试过程中,可能会出现因测试环境不稳定、网络慢等情况&a…...
苹果手机照片如何导入电脑?无损快速的传输办法分享!
前些天小编的朋友联系到我,说是自己苹果手机里面的照片太多,有好几千张,不知道该怎么快而无损地传到电脑。我想遇到这种情况的不止是小编的朋友,生活中遇到手机照片导入电脑的同学不在少数。不管是苹果手机还是安卓手机࿰…...
csh 脚本批量处理文件并将文件扔给程序
文章目录 前言程序批量造 case 并将 cmd 扔给程序运行批量收集数据汇总 前言 Linux下我们经常会写一些shell脚本来辅助我们学习或者工作,从而提高效率。 之前就写过一篇博客:Linux下利用shell脚本批量产生内容有规律变化的文件 程序 批量造 case 并将…...
程序员技能成长树,程序员的曙光
一、背景 初创的计算机公司,主要低市场占有率和日益增长的市场规模之间的矛盾,此时只有一件事情,那就是快速抢占市场,在面对计算机飞速发展的时期,企业广泛的招聘计算机人才进行信息化项目建设,随着公司业…...
灰度图处理方法
做深度学习项目图像处理的时候常常涉及到灰度图处理,这里对自己处理灰度图的方式做一个记录,后续有更新的话会在此更新 一,多维数组可视化 将多维数组可视化为灰度图 img_gray Image.fromarray(img, modeL) # 实现array到image的转换,m…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
循环冗余码校验CRC码 算法步骤+详细实例计算
通信过程:(白话解释) 我们将原始待发送的消息称为 M M M,依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)(意思就是 G ( x ) G(x) G(x) 是已知的)࿰…...
线程同步:确保多线程程序的安全与高效!
全文目录: 开篇语前序前言第一部分:线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分:synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分ÿ…...
在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
【Go语言基础【12】】指针:声明、取地址、解引用
文章目录 零、概述:指针 vs. 引用(类比其他语言)一、指针基础概念二、指针声明与初始化三、指针操作符1. &:取地址(拿到内存地址)2. *:解引用(拿到值) 四、空指针&am…...
【LeetCode】算法详解#6 ---除自身以外数组的乘积
1.题目介绍 给定一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O…...
在 Visual Studio Code 中使用驭码 CodeRider 提升开发效率:以冒泡排序为例
目录 前言1 插件安装与配置1.1 安装驭码 CodeRider1.2 初始配置建议 2 示例代码:冒泡排序3 驭码 CodeRider 功能详解3.1 功能概览3.2 代码解释功能3.3 自动注释生成3.4 逻辑修改功能3.5 单元测试自动生成3.6 代码优化建议 4 驭码的实际应用建议5 常见问题与解决建议…...
车载诊断架构 --- ZEVonUDS(J1979-3)简介第一篇
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 做到欲望极简,了解自己的真实欲望,不受外在潮流的影响,不盲从,不跟风。把自己的精力全部用在自己。一是去掉多余,凡事找规律,基础是诚信;二是…...
