全栈面试(一)Basic/微服务

news2025/1/11 10:15:36

文章目录

  • 项目地址
  • 一、Basic InterviewQuestions
        • 1. tell me about yourself?
        • 2. tell me about a time when you had to solve a complex code problem?
        • 3. tell me a situation that you persuade someone at work?
        • 4. tell me a about a confict with a teammate and how you resolved it
        • 5. tell me a about a time where you demonstarted leadership
        • 6. imagine that your teammate was not performing well how would you handle the situation ?
        • 7. what would you manager say about you
        • 8 . why do you want to work here
      • 9. tell me about a time when you above call the of duty
      • 10. what project are you most proud of and why
  • 二、全栈
    • 2.1 微服务
        • 1. 订单搜索功能
      • 2. RabbitMQ
        • 2.1 RabbitMQ的架构或者组成部分
        • 2.2 延迟队列和死信
        • 2.3 如何保证消息发送或者接收
        • 2.4 常用的队列
        • 2.5 如何保消息不被重复消费
        • 2.6 消息队列的优缺点以及场景
      • 3. Kafka
        • 3.1 简述kafka的架构设计
        • 3.1 简述kafka的rebalance机制
      • 4. Redis
        • 4.1 分布式ID的生成方案
        • 4.2 分布式锁的应用场景以及解决方法
        • 4.3 死锁的情况有哪些
        • 4.4 redis持久化RDB 和AOF
        • 4.5 redis如何淘汰过期的key
        • 4.6 缓存回收


项目地址

  • 教程作者:
  • 教程地址:
  • 代码仓库地址:
  • 所用到的框架和插件:
dbt 
airflow

一、Basic InterviewQuestions

在这里插入图片描述

1. tell me about yourself?

First of all, thank you very much for give me this opportunity,I am a software engineer, I enjoy sloving complex problems I have experience as a Data enginner for one half year and 2 years building and mantaining Full stactk web app. I enjoy working with all layers of the stack. 在我之前工作中,I’v experienced with include .net for building mvc and web api and as well as experience with different various javascript framworks such as react and vue. So i believe my passion and my experience would make me a great asset for you company

2. tell me about a time when you had to solve a complex code problem?

Use S.T.A.R

3. tell me a situation that you persuade someone at work?

my previous company our team support different web applications and there was really uniformity in terms of what kind of technic or framework we should use. 之前有个项目是需要从一个网站获取接口数据,将数据结合bi系统数据,进行实时的展示,所以刚开始领导决定使用和后端一样的.net 完成功能。我提出了可以使用python完成,因为更加轻量化的定时系统和更快的开发周期。就写了一个小的demo在周会上演示利与弊,最后,小组的成员以及leader同意了我的想法

4. tell me a about a confict with a teammate and how you resolved it

star

5. tell me a about a time where you demonstarted leadership

star

  1. 先说一个leadership应该有啥:可以将项目有条不紊的组织起来,并且善于发掘每个人的特长
  2. 之前有个新来的同事,领导让我带着他熟悉公司的业务,之后一起合作开发
6. imagine that your teammate was not performing well how would you handle the situation ?

不要用star

  1. 如何更好的像teammate传达坏消息,但是不要贬低他,先赞扬,在讲出问题,最后再 赞美和鼓励
7. what would you manager say about you
  1. 有创造力,善于学习,学习的很快
  2. 公开演讲,或者小组开会上,我说话并不是很多,不是一个能活跃气氛的人?
8 . why do you want to work here
  1. 对产品兴奋,对公司的业务感兴趣
  2. 你的技术和公司的技术很匹配

9. tell me about a time when you above call the of duty

star

  1. 新年回去了,但是,我的服务器报警了,我的定时任务报警,原本应该有1000w的吞吐,但是,当日只有10w数据,

10. what project are you most proud of and why

多平台协作+微服务

二、全栈

2.1 微服务

1. 订单搜索功能
  • 数据同步架构图

在这里插入图片描述

执行流程:
1.数据存储,数据到达订单数据库后,会到Canal服务器,Canal服务器通过
同步通讯,到ElasticSearch服务
2. Canal和Els默认使用的时http通讯,使用RabbitMQ进行通讯或kafka
3. 数据回源:解决异步通讯实时延迟问题,出现延迟的数据,直接再订单数据库里进行查询
4. 数据回源并发量大会导致订单数据库性能下降,所以需要添加一个redis缓存服务

技术:
5. 电商微服务系统
6. Elasticsearch
7. Nest
8. Cannal
9. RabbitMQ
10.Redis

具体实现:

  1. 使用Nest提供的ElasticClient

2. RabbitMQ

2.1 RabbitMQ的架构或者组成部分
  1. broker :服务节点
  2. queue:队列,用户存储消息,多个消费者订阅一个队列,这是队列的消息会被轮询 平摊给多个消费者。
  3. exchange: 交换器,生产者发送消息给exchange,然后exchange将消息放入一个或者多个队列中
  4. RoutingKey:当消息到达exchange的时候,会指定一个RoutingKey,用来指定路由规则,必须和bindingKey一起使用才可以生效
  5. Binding:通过绑定,将exchange和queue里的消息绑定,
2.2 延迟队列和死信

在这里插入图片描述

2.3 如何保证消息发送或者接收

发送方:需要发送confirm,当消息到达生产者的时候,使用comfirmCallback回调接口,成功则回调,失败则调用ReturnCallback接口
接收方: 消费者接收的每一条消息后必须确认,只有确认了的消息,才会从队列里删除。但是如果消费者 返回ack之前断开了连接,消息会被从新发给下一个订阅的消费者,这样会产出重复消费,需要进行去重
broker: 同步刷盘,等待slave复制完成才会返沪确认

2.4 常用的队列
  1. 镜像队列:队列会在集群上的多个节点创建副本,主节点处理请求, 子节点负责同步数据,当主节点宕机,子节点接管,保证高可用
  2. 优先队列:处理系统预警
  3. 延迟队列:订单超时(20分钟内,用户未支付,取消订单)
2.5 如何保消息不被重复消费
  • MQ是无法保证消费端是否正常消费的
  • 需要程序员从应用端保证消息不被重复消息,需要保证消息的幂等性:
    1. 如果使用redis,每次都是set, 天然幂等
    2. 生产者发送消息带上全局唯一uuid,消费者拿到消息后,根据id在redis里查询,没消费过就处理,并且写入id到redis里,如果消费过,就不处理
2.6 消息队列的优缺点以及场景

有点: ①异步 ②解耦 ③消弱峰值
缺点: ①复杂度②数据一致性,消费者会失败
场景: ①日志采集 ② 订阅发布 ③多系统调用

3. Kafka

在这里插入图片描述

3.1 简述kafka的架构设计
  1. broker:服务器节点,可以有多个
  2. topic: 一个Topic 以多个partition的方式分布在多个broker上,每个p
  3. Customer group:消费者分组
3.1 简述kafka的rebalance机制

4. Redis

4.1 分布式ID的生成方案
  1. 全局的uuid:优点:降低全局节点压力;缺点:占空间大,不是递增的
  2. 数据库主键自增:优点:数字类型查询效率高于字符;缺点:并发性能不好,分库分表复杂
  3. Redis自增: 优点:并发性能高;缺点:数据丢失,自增
  4. 雪花算法:优点:分布式ID的经典算法; 缺点:时钟回拨
4.2 分布式锁的应用场景以及解决方法

应用场景:

  1. 处理分布式系统集群中的锁,如果都是用独立的锁,锁就没有意义
  2. 操作共享资源:如数据库里唯一用户资源,订单系统,优惠卷系统,财务系统
  3. 同步访问:多个进程同时操作共享资源

解决方案:
4. 使用redis做分布式锁,使用setnx key nx ex 10s(需要给key设置过期时间5-10s)确保不会有死Key;其次,如果锁设置了10s释放 ,但是 执行了15s,另外一个程序已经获取到了锁,会出现数据不一致,需要使用watch dog进行,实际上直接使用框架lock 和unlock
5. 基于zookeeper,临时节点(客户端和zookeeper连接后一直生效,断开后连接失效),顺序节点:1号服务拿锁,执行结束后,再给2号
6. 基于基于数据库,主键或者唯一索引

4.3 死锁的情况有哪些
  1. 加锁,但是没释放锁,需要添加Delete key
  2. 加锁后,程序还没执行释放锁,程序挂了,需要添加key的过期机制
4.4 redis持久化RDB 和AOF

RDB:
1. 数据快照,指定间隔时间内,对数据进行快照存储;
2. 保存某个时间点的数据,如每小时保存过去24小时数据,同时每天保存过去30天的数据;
3. 方便传入到blob里
4. 缺点:①意外停止,会丢失数据;②fork子进程进行数据备份会导致性能降低;

AOF(优先):
1. 每秒的fsync策略,AOF可以将数据丢失降低到1s
2. AOF只是一个日志追加文件,所以即使宕机,也可以恢复到未执行完整的写入命令
3. AOF保存数据库所有执行写入的操作
4. 缺点:体积大

4.5 redis如何淘汰过期的key
  1. 自动:每10s 随机检测20个keys进行过期检测,删除所有的过期keys,如果多于25%就重复1
  2. 手动:设置master执行DEL命令,如果Master不执行,slaver是不会执行的
  3. 扩展:绝对时间点和相对时间点以及时钟轮算法
4.6 缓存回收

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2274852.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

医疗可视化大屏 UI 设计新风向

智能化交互 借助人工智能与机器学习技术,实现更智能的交互功能。如通过语音指令或手势控制来操作大屏,医护人员无需手动输入,可更便捷地获取和处理信息。同时,系统能根据用户的操作习惯和数据分析,自动推荐相关的医疗…

Angular由一个bug说起之十三:Cross Origin

跨域 想要了解跨域,首要要了解源 什么是源,源等于协议加域名加端口号 只有这三个都相同,才是同源,反之则是非同源。 比如下面这四个里,只有第4个是同源 而浏览器给服务器发送请求时,他们的源一样&#xff0…

【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间

贪心算法 买卖股票的最佳时机买卖股票的最佳时机II跳跃游戏跳跃游戏II划分字母区间 买卖股票的最佳时机 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的…

MCANet: 基于多模态字幕感知的大语言模型训练无关视频异常检测

目录 摘要01 引言02 相关工作2.1 视频异常检测2.2 基于视频的大语言模型(VLLMs) 03 方法论3.1 问题定义3.2 MCANet3.3 图像字幕分支3.4 音频字幕分支3.5 基于LLM的异常评分3.6 视频-文本分数优化 04 实验4.1 数据集和评估指标4.2 实现细节4.3 定性结果4.…

为深度学习引入张量

为深度学习引入张量 什么是张量? 神经网络中的输入、输出和转换都是使用张量表示的,因此,神经网络编程大量使用张量。 张量是神经网络使用的主要数据结构。 张量的概念是其他更具体概念的数学概括。让我们看看一些张量的具体实例。 张量…

Taro+Vue实现图片裁剪组件

cropper-image-taro-vue3 组件库 介绍 cropper-image-taro-vue3 是一个基于 Vue 3 和 Taro 开发的裁剪工具组件,支持图片裁剪、裁剪框拖动、缩放和输出裁剪后的图片。该组件适用于 Vue 3 和 Taro 环境,可以在网页、小程序等平台中使用。 源码 https:…

[DO374] Ansible 配置文件

[DO374] Ansible 配置文件 1. 配置文件位置2. 配置文件3. Ansible 配置4. Ansible的Ad-hoc5. Ansible 模块6. playbook段落7. 任务执行后续8. Ansible 变量8.1 ansible 变量的定义8.1.1 主机变量8.1.2 主机组变量 8.2 vars的循环 9. Ansible Collection10. Ansible-galaxy 安装…

[程序设计]—代理模式

[程序设计]—代理模式👳 本文章记录学习于——52.面向切面:AOP-场景模拟_哔哩哔哩_bilibili 最近闲来无事,在学习Spring的源码: 后面慢慢更新源码系列blog,希望多多关注🙏🙏 目前已经总结的b…

OSPF - 2、3类LSA(Network-LSA、NetWork-Sunmmary-LSA)

前篇博客有对常用LSA的总结 2类LSA(Network-LSA) DR产生泛洪范围为本区域 作用:  描述MA网络拓扑信息和网络信息,拓扑信息主要描述当前MA网络中伪节点连接着哪几台路由。网络信息描述当前网络的 掩码和DR接口IP地址。 影响邻居建立中说到…

景芯SOC设计实战

终身辅导、一对一辅导,手把手教您完成SoC全流程设计,从入门到进阶,带您掌握SoC芯片架构、算法、设计、验证、DFT、后端及低功耗全流程!直播视频不定期升级!让您快速超越同龄人! 景芯团队主打文档服务器实战…

多云架构,JuiceFS 如何实现一致性与低延迟的数据分发

随着大模型的普及,GPU 算力成为稀缺资源,单一数据中心或云区域的 GPU 资源常常难以满足用户的全面需求。同时,跨地域团队的协作需求也推动了企业在不同云平台之间调度数据和计算任务。多云架构正逐渐成为一种趋势,然而该架构下的数…

如何获取文件的MIME类型

文章目录 1. 概念介绍2. 方法与类型2.1 使用方法2.2 常见类型3. 示例代码4. 内容总结我们在上一章回中介绍了"如何加载本地图片"相关的内容,本章回中将介绍如何获取文件类型.闲话休提,让我们一起Talk Flutter吧。 1. 概念介绍 我们在本章回中提到的文件类型是指MI…

【Uniapp-Vue3】computed计算属性用法及方法对比

如果我们想要将两个响应式变量进行某种运算,就可以使用computed计算属性。 比如下面这个例子中,输入名和姓合成全名,可以用直接显示的方法: 我们也可以使用computed属性: import {computed} from "vue"; le…

C#实现凸壳算法

凸壳计算代码: public static PointD[] calcConvexHull(PointD[] points) {// 按 x 坐标对点进行排序Array.Sort(points, (p1, p2) => p1.X.CompareTo(p2.X));// 创建下凸壳var lowerHull = new List<PointD>();foreach (var point in points){while (lowerHull.Co…

设计模式 行为型 状态模式(State Pattern)与 常见技术框架应用 解析

状态模式&#xff08;State Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许对象在内部状态改变时改变其行为&#xff0c;使得对象看起来好像修改了它的类。这种设计模式的核心思想是将对象的状态和行为封装成不同的状态类&#xff0c;通过状态对象的行为改变来避免…

SAP SD学习笔记27 - 贩卖契约(框架协议)2 - 基本契约 - 金额契约(价值合同)

上一章讲了贩卖契约&#xff08;框架协议&#xff09;的概要&#xff0c;以及贩卖契约中最为常用的 基本契约 - 数量契约。 SAP SD学习笔记26 - 贩卖契约(框架协议)的概要&#xff0c;基本契约 - 数量契约-CSDN博客 本章继续讲SAP中的内容&#xff1a; - 基本契约 - 金额契约…

mysql之基本select语句 运算符 排序分页

1.SQL的分类 DDL:数据定义语言. CREATE ALTER DROP RENAME TRUNCATE DML: 数据操作语言. INSERT DELETE UPDATE SELECT 重中之重 DCL: 数据控制语言. COMMIT ROLLBACK SAVEPOINT GRANT REVOKE 2.SQL语言的规则与规范 1.基本规则 SQL可以在一行或多行,为了提高可…

Linux中SSH服务(二)

一、基于公私钥的认证&#xff08;免密登录&#xff09; 1、Windows免密登录Linux Windows推荐安装Cygwin软件&#xff1a;Cygwin 1.1Windows上面生成公私钥 之前已经生成过了&#xff0c;所以显示公私钥已存在 lovezywLAPTOP-AABHB5ED ~ $ ssh-keygen Generating public/pr…

.NET Core NPOI 导出图片到Excel指定单元格并自适应宽度

NPOI&#xff1a;支持xlsx&#xff0c;.xls&#xff0c;版本>2.5.3 XLS&#xff1a;HSSFWorkbook&#xff0c;主要前缀HSS&#xff0c; XLSX&#xff1a;XSSFWorkbook&#xff0c;主要前缀XSS&#xff0c;using NPOI.XSSF.UserModel; 1、导出Excel添加图片效果&#xff0…

NS2202X 系列 40V 输入 OVP 保护 IC

1 特性  最大输入电压&#xff1a; 40V  内部预设 2.1A 负载过流 OCP 保护  外置过流保护阈值可调节引脚&#xff0c;可悬空  外置 EN 使能控制引脚  内部预设 6V 输入过压 OVP 保护  输入 OVP 保护响应时间 20ns  内置 150 ℃过温…