当前位置: 首页 > news >正文

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


文章目录

  • 项目地址
  • 一、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 缓存回收

相关文章:

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

文章目录 项目地址一、Basic InterviewQuestions1. 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…...

python安装完成后可以进行的后续步骤和注意事项

安装Python3完成后,你可以开始使用它进行编程和开发。以下是一些安装完成后可以进行的后续步骤和注意事项: 验证安装 检查Python版本: 打开“终端”应用程序。输入python3 --version,应该显示安装的Python3版本号。 检查pip版本…...

[Qt] 窗口 | 菜单栏MenuBar

目录 QMainWindow 概述 一、菜单栏 1、创建菜单栏 2、在菜单栏中添加菜单 3、创建菜单项 4、在菜单项之间添加分割线 5、添加快捷键 6、添加子菜单 7、添加图标 综合示例 QMainWindow 概述 Qt 窗口是通过 QMainWindow 类来实现的。 QMainWindow 是一个为用户 提供主…...

[读书日志]从零开始学习Chisel 第十三篇:Scala的隐式参数与隐式转换(敏捷硬件开发语言Chisel与数字系统设计)

10. 隐式转换与隐式参数 假设编写了一个向量类MyVector,并且包含一些向量的基本操作。因为向量可以与标量做数乘运算,所以需要一个计算数乘的方法“*”,它应该接收一个类型为基本值类的参数,在向量对象myVec调用该方法时&#xf…...

CMake学习笔记(1)

1. CMake概述 CMake 是一个项目构建工具,并且是跨平台的。关于项目构建我们所熟知的还有Makefile(通过 make 命令进行项目的构建),大多是IDE软件都集成了make,比如:VS 的 nmake、linux 下的 GNU make、Qt …...

cursor+deepseek构建自己的AI编程助手

文章目录 准备工作在Cursor中添加deepseek 准备工作 下载安装Cursor (默认安装在C盘) 注册deepseek获取API key 在Cursor中添加deepseek 1、打开cursor,选择设置 选择Model,添加deepseek-chat 注意这里去掉其他的勾选项&…...

Kotlin实现DataBinding结合ViewModel的时候,提示找不到Unresolved reference: BR解决方案

在用Kotlin语言实现DataBinding结合ViewModel的代码的时候,如下所示: class UserModel(private val userName: String, private val userAge: Int) : BaseObservable() {get:Bindablevar name: String userNameset (value) {field valuenotifyPropert…...

java项目启动时,执行某方法

1. J2EE项目 在Servlet类中重写init()方法,这个方法会在Servlet实例化时调用,即项目启动时调用。 import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;public class MyServlet extends HttpServlet {Overridepublic void …...

详解如何自定义 Android Dex VMP 保护壳

版权归作者所有,如有转发,请注明文章出处:https://cyrus-studio.github.io/blog/ 前言 Android Dex VMP(Virtual Machine Protection,虚拟机保护)壳是一种常见的应用保护技术,主要用于保护 And…...

Grails应用http.server.requests指标数据采集问题排查及解决

问题 遇到的问题:同一个应用,Spring Boot(Java)和Grails(Groovy)混合编程,常规的Spring Controller,可通过Micromete Pushgateway, 采集到http.server.requests指标数据,注意下面的指标名称是点号&#…...

开源临床试验软件OpenClinica的安装

本文是为帮网友 A萤火虫 解决安装问题做的记录; 简介 什么是 OpenClinica ? OpenClinica 是世界上第一个商业开源临床试验软件,主要用于电子数据捕获(EDC)和临床数据管理(CDM)。它的设计旨在优…...

网络安全 | 网络安全法规:GDPR、CCPA与中国网络安全法

网络安全 | 网络安全法规:GDPR、CCPA与中国网络安全法 一、前言二、欧盟《通用数据保护条例》(GDPR)2.1 背景2.2 主要内容2.3 特点2.4 实施效果与影响 三、美国《加利福尼亚州消费者隐私法案》(CCPA)3.1 背景3.2 主要内…...

深入学习 Python 爬虫:从基础到实战

深入学习 Python 爬虫:从基础到实战 前言 Python 爬虫是一个强大的工具,可以帮助你从互联网上抓取各种数据。无论你是数据分析师、机器学习工程师,还是对网络数据感兴趣的开发者,爬虫都是一个非常实用的技能。在本文中&#xff…...

element plus 使用 upload 组件达到上传数量限制时隐藏上传按钮

最近在重构项目,使用了 element plus UI框架,有个功能是实现图片上传,且限制只能上传一张图片,结果,发现,可以限制只上传一张图片,但是上传按钮还在,如图: 解决办法&…...

音频DSP的发展历史

音频数字信号处理(DSP)的发展历史是电子技术、计算机科学和音频工程共同进步的结果。这个领域的进展不仅改变了音乐制作、音频后期制作和通信的方式,也影响了音频设备的设计和功能。以下是对音频DSP发展历史的概述: 早期概念和理论…...

2025低代码与人工智能AI新篇

在当今数字化浪潮汹涌澎湃的时代,低代码开发与人工智能(AI)犹如两颗璀璨的星辰,正逐渐交汇融合,为企业解锁前所未有的智能业务解决方案。今天,咱们就深入探讨一下低代码平台是如何集成 AI 技术,…...

【HarmonyOS Next NAPI 深度探索1】Node.js 和 CC++ 原生扩展简介

【HarmonyOS Next NAPI 深度探索1】Node.js 和 CC 原生扩展简介 如果你用过 Node.js,应该知道它强大的地方在于能处理各种场景,速度还很快。但你有没有想过,Node.js 的速度秘密是什么?今天我们来聊聊其中一个幕后英雄——原生扩展…...

redis的学习(四)

13. 渐进式遍历 通过渐进式遍历能够获取当前所有的key,又不会讲当前的服务器卡死。不是一个命令将所有的key获取,而是每执行一次命令,只获取到其中的一部分。所以想要获取到所有的key就需要多次遍历,即化整为零的思想。 渐进式遍历…...

C# winform 多线程 UI更新数据 报错:无法访问已释放的对象。

System.ObjectDisposedException HResult0x80131622 Message无法访问已释放的对象。 ObjectDisposed_ObjectName_Name SourceSystem.Windows.Forms StackTrace: at System.Windows.Forms.Control.MarshaledInvoke(Control caller, Delegate method, Object[] args, …...

error: linker `link.exe` not found

开始学习rust,安装好rust的环境,开始从hello world开始,结果用在win10环境下,使用vs code或cmd窗口编译rust报错: PS E:\study_codes\rust-demo\chart01> rustc hello.rs error: linker link.exe not found| note:…...

【网络】每天掌握一个Linux命令 - iftop

在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

vscode里如何用git

打开vs终端执行如下: 1 初始化 Git 仓库(如果尚未初始化) git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)

一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...

.Net框架,除了EF还有很多很多......

文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...

《从零掌握MIPI CSI-2: 协议精解与FPGA摄像头开发实战》-- CSI-2 协议详细解析 (一)

CSI-2 协议详细解析 (一) 1. CSI-2层定义(CSI-2 Layer Definitions) 分层结构 :CSI-2协议分为6层: 物理层(PHY Layer) : 定义电气特性、时钟机制和传输介质(导线&#…...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

Java多线程实现之Callable接口深度解析

Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...

【SQL学习笔记1】增删改查+多表连接全解析(内附SQL免费在线练习工具)

可以使用Sqliteviz这个网站免费编写sql语句,它能够让用户直接在浏览器内练习SQL的语法,不需要安装任何软件。 链接如下: sqliteviz 注意: 在转写SQL语法时,关键字之间有一个特定的顺序,这个顺序会影响到…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...