大厂面试官赞不绝口的后端技术亮点【后端项目亮点合集(2)】

本文将持续更新~~

 hello hello~ ,这里是绝命Coding——老白~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹

💥个人主页:绝命Coding-CSDN博客
💥 所属专栏:后端技术分享
这里将会不定期更新有关后端、前端的内容,希望大家多多点赞关注收藏💖

历史文章:

后端项目亮点合集(1):Redis篇_后端项目有什么亮点-CSDN博客

本文的作用:

(1)简历优化:针对自己的简历,对Redis亮点进行优化升级,或者进行补充;

(2)项目设计提供参考:下文中的Redis解决方案和最佳实践可以作为项目设计的参考;

(3)搜索导向与教程查找:下文的关键词和技术点可以作为搜索相关教程和资料的搜索项;

温馨提示:

在写项目亮点的时候,尽可能地量化出结果,并且适当加粗,比如:“使用Redis缓存,将请求时间500ms降低至25ms,大大提升了系统性能”

                              ——来自求职经验分享(1):一份合格的简历应该如何写?-CSDN博客

一、消息队列(Kafka、RabbitMQ)

  1. 使用消息队列(如 Kafka)实现评论功能的异步削峰,减轻系统的负载压力。
  2. 对评论功能进行了预加载,提高响应速度。
  3. 使用 Canal 结合消息队列实现数据库和缓存的同步,保证数据的一致性。
  4. 使用验证码 + 消息队列方式对秒杀接口进行限流,实现削峰填谷;同时使用消息队列实现异步订单处理。(适用于电商秒杀系统)
  5. 使用消息队列实现订单延迟关闭功能。
  6. 使用 RabbitMQ 的死信队列实现自动取消订单功能。
  7. 使用消息队列实现海量数据的异步推送。
  8. 使用 RabbitMQ 进行结果通知,基于延迟队列处理超时未支付订单。

二、ElasticSearch

  1. 基于 ElasticSearch 的机器人对话功能,通过 ElasticSearch 分词查询提高回复内容的准确性。
  2. 使用 ElasticSearch 结合中文分词器和拼音分词器实现搜索时自动补全功能。
  3. 使用 ElasticSearch 实现文章内容的快速查找。/ 使用 ElasticSearch 实现知识库。
  4. 使用 ElasticSearch 存储账户信息进行模糊提示。
  5. XX发布使用本地消息表XXL-Job 实现分布式事务控制,使用 Elasticsearch 为XX建立索引,提高XX检索效率。
  6. 使用 ElasticSearch 搜索引擎优化帖子搜索的功能,并使用 Quartz 定时计算帖子的分数,实现热帖排行。

三、MySQL

  1. 数据库使用 Mycat 实现分库分表,以及两主两从读写分离
  2. 使用乐观锁解决超卖问题(适用于电商秒杀系统)。
  3. 使用主键分页 INNER JOIN 延迟关联优化深分页问题。
  4. 使用 JDBC事务的批量操作,将数据分批插入到数据库中,以提高效率和性能。
  5. 修复慢查询问题,通过使用线程池将 in 子查询进行分批处理,提高查询效率。
  6. 使用乐观锁解决并发冲突
  7. 查询千万数据,利用 SQL 事务和多线程提高大量插入的速度,避免内存溢出。

四、多线程

  1. 将耗时的业务逻辑封装,通过启动固定数量的线程,从队列中取出任务进行异步执行,防止接口响应超时。
  2. 使用 Completablefuture 线程池异步的方式实现商品的页面显示,将不同表的操作异步调用后任务结合返回数据。
  3. 通过 ReentrantLock+自旋锁机制解决 Token 刷新问题,避免大量用户同时请求,减少大量资金损耗。
  4. 使用 Disruptor 替代异步编排 Completablefuture 和线程池,解决多线程下的事件驱动问题,提高系统吞吐量。

五、文件操作

  1. 使用 Files.walk(source).parallel() 进行文件移动,利用多线程并行处理,减少 I/O 操作和 CPU 等待时间。(适用于需要上传文件的项目)
  2. 使用 NIO 中的 FileChannel 类进行文件下载,利用零拷贝特性,提高文件移动速度。
  3. 使用 WebUpload 中间件实现大文件的分片上传,并利用 MD5 实现重传秒传(断点续传)功能,提高文件上传速度。
  4. 使用 EasyExcel 实现 Excel 文件批量导入和导出。
  5. 使用 MinIO 高性能对象存储实现图片和视频等文件的存储。

六、安全

  1. 使用 JWT 实现注册分布式单点登录,以及用户信息校验,保障登录用户信息安全。
  2. 使用时间戳+nonce方案防止重放攻击。
  3. API接口进行签名,防止数据被篡改。
  4. 使用接口隐藏(接口加盐)和状态模式设计模式来实现秒杀接口的防刷限流。(适用于秒杀系统)
  5. 实现第三方Gitee登录。
  6. 使用 SpringSecurity 实现用户登录。

七、其他

  1. 使用预先设定好的敏感词初始化前缀树,实现对用户发布的敏感词进行过滤。
  2. 使用 RateLimiter 类 或者 Redis + Lua 脚本实现接口限流。
  3. 使用 WebSocket 实现用户下单或催单时能够给管理端进行提醒,避免了商家频繁查看订单页面。
  4. 使用 WebSocket 实现在线聊天功能(适用于聊天模块,如好友私聊、客服聊天)。
  5. 使用 SpringTask 处理超时订单,避免手动操作。
  6. 使用 Quartz 任务调度框架,定期更新话题浏览量。
  7. 使用雪花算法生成分布式 ID
  8. 使用防重 Token 令牌实现接口幂等性。
  9. 使用 FreeMarker 自动生成增删查改代码(适用于代码生成项目)。
  10. 使用 Jenkins + Docker 进行自动化部署和持续集成,解决微服务项目部署繁琐的问题。
  11. 使用 XXL-Job 作为分布式任务调度平台,实现长任务的异步处理。
  12. 使用 AOP+TraceID 记录接口访问日志,实现任务的追踪、监控和诊断。
  13. 使用 Xxl-job 定时将新增记录更新到数据库做备份,提高系统性能和响应速度。
  14. 设计 API 签名认证算法,为用户分配唯一 ak/sk 以鉴权,保障调用的安全性。
  15. 使用 Java Runtime 对象的 exec 方法实现了对 Java 程序的编译和执行,并使用 Docker 隔离用户代码,实现了更安全的代码沙箱。(适用于 OJ 平台)
  16. 使用 Elastic Stack 搭建日志收集系统,对调试日志、业务日志、错误日志、接口访问日志进行分场景监控。

八、第三方集成

  1. 使用 SpringBoot 对接支付宝,实现支付模块。
  2. 使用七牛云 OSS 对象存储存储菜品图片,加快图片响应速度。

九、SpringCloud

  1. 使用 GateWay 网关解决跨域问题,以及路由转发。
  2. 各服务间通过 Fegin/Dubbo 进行同步通信。
  3. 使用 Sentinel 实现微服务的流控、隔离、熔断降级等功能。
  4. 使用 Seata 解决分布式事务问题,采用 AT 模式,构建 undolog 日志表,实现数据最终一致性。

十、设计模式

  1. 使用 Builder 模式构建复杂对象。
  2. 使用责任链模式重构请求数据准确性检验。
  3. 使用策略模式实现评论服务,根据不同业务场景选择合适的评论方案。
  4. 实现 OAuth2.0 协议时,采用策略模式为接入用户中心的应用提供三类授权服务。

 后续将推出

(1)持续更新文章:消息队列、Elasticsearch、Mysql、多线程、文件操作、安全、设计模式等亮点集合;

(2)基于上述文章亮点的具体实现以及面试八股文细节;

(欢迎点赞收藏关注~~)

更多历史精彩文章:

求职经验分享(1):一份合格的简历应该如何写?-CSDN博客

求职经验分享(2):简历如何优化以及如何应对面试【后端篇】-CSDN博客

求职经验分享(3):如何找到理想的应届生求职项目?【后端篇】-CSDN博客

想要快速掌握Redis、消息队列、Elasticsearch、MySQL以及多线程等技术的最新亮点和合集吗?现在,老白特别为您准备了一份全面的技术亮点合集(持续更新中),请关注公众号后台私信“ 技术亮点合集”,即可免费获取!

感兴趣的小伙伴,千万不要错过这个机会!关注我们的公众号:绝命Coding

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

第三方商城对接重构(HF202407)

文章目录 项目背景一、模块范围二、问题方案1. 商品模块整体来说这块对接的不是太顺利,梳理了几条大概的思路:2. 订单模块3. 售后4. 发票5. 结算单经验总结项目背景 作为供应商入围第三方商城成功,然后运营了一段时间,第三方通知要重构, 需要重新对接打通接口完成系统对接…

【网络管理工具】NETworkManager工具的基本使用教程

【网络管理工具】NETworkManager工具的基本使用教程 一、NETworkManager工具介绍1.1 NETworkManager简介1.2 NETworkManager特点1.3 NETworkManager使用场景 二、下载NETworkManager软件包2.1 下载地址2.2 下载软件 三、运行NETworkManager工具3.1 解压NETworkManager3.2 运行N…

WPF中Background=“{x:Null}“ 和 Transparent

WPF中关于背景透明和背景无 此时&#xff0c;我代码中是写的有有个控件&#xff0c;一个Border &#xff0c;一个TextBox &#xff0c;范围都是全屏这么大&#xff0c;可以输入TextBox 因为&#xff0c;当border没有设置背景的时候&#xff0c;实际上是&#xff1a; <Borde…

实现原理:远程过程调用(RPC)

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f4a5;&#x1f4a5;个人主页&#xff1a;奋斗的小羊 &#x1f4a5;&#x1f4a5;所属专栏&#xff1a;C语言 &#x1f680;本系列文章为个人学习…

Linux多进程和多线程(七)进程间通信-信号量

进程间通信之信号量 资源竞争 多个进程竞争同一资源时&#xff0c;会发生资源竞争。 资源竞争会导致进程的执行出现不可预测的结果。 临界资源 不允许同时有多个进程访问的资源, 包括硬件资源 (CPU、内存、存储器以及其他外 围设备) 与软件资源(共享代码段、共享数据结构) …

2024上半年网络工程师考试《应用技术》试题二

试题二(20分) 阅读以下说明,回答问题,将解答填入对应的解答栏内。 某单位网络拓扑如下图所示.SW1、SW2为核心层交换机&#xff0c;PC网关配置在核心层&#xff0c;SW3-SW4为接入层交换机,行政部PC划为vlan10,销售部PC划为vlan20。 【问题1】(4分) 要求实现骨干链路冗余&…

[leetcode hot 150]第一百三十题,被围绕的区域

题目&#xff1a; 给你一个 m x n 的矩阵 board &#xff0c;由若干字符 X 和 O 组成&#xff0c;捕获 所有 被围绕的区域&#xff1a; 连接&#xff1a;一个单元格与水平或垂直方向上相邻的单元格连接。区域&#xff1a;连接所有 0 的单元格来形成一个区域。围绕&#xff1a…

图的应用之最短路径

引入 应用 算法思想 Dijistra算法 用于解决单个顶点间的最短路径问题 将顶点看成两部分&#xff1a; 最短路径顶点集合A与尚未确定最短路径顶点集合B。 先将顶点按最短路径由小到大依次加入到A中&#xff0c;选择由源点到A中最短的顶点&#xff0c;并记录距离与顶点&#xf…

154. 寻找旋转排序数组中的最小值 II(困难)

154. 寻找旋转排序数组中的最小值 II 1. 题目描述2.详细题解3.代码实现3.1 Python3.2 Java 1. 题目描述 题目中转&#xff1a;154. 寻找旋转排序数组中的最小值 II 2.详细题解 该题是153. 寻找旋转排序数组中的最小值的进阶题&#xff0c;在153. 寻找旋转排序数组中的最小值…

讲个SystemVerilog随机约束小坑

正文 记录个在写SystemVerilog随机约束时遇到的一个小坑&#xff0c;如果没有认真去查看随机结果是否符合预期&#xff0c;还真不容易发现。 为了方便讲述&#xff0c;写了如下示例代码。类cl_a里有个随机变量aa&#xff0c;初始值为222。在module top里对类cl_a例化并进行约…

【Web】

1、配仓库 [rootlocalhost yum.repos.d]# vi rpm.repo ##本地仓库标准写法 [baseos] namemiaoshubaseos baseurl/mnt/BaseOS gpgcheck0 [appstream] namemiaoshuappstream baseurlfile:///mnt/AppStream gpgcheck0 2、挂载 [rootlocalhost ~]mount /dev/sr0 /mnt mount: /m…

EFUSE中redundancy program/read的理解

现在有空&#xff0c;整理下前段时间关于efuse中redundancy program/read模式的理解&#xff0c;下面以TEF22ULP128X32HD18_PURM这款芯片为例&#xff0c;进行笔记整理&#xff0c;如有侵权或不妥之处&#xff0c;请时告知并及时处理。 1 redundancy的作用 efuse中存放的是芯…

跨平台书签管理器 - Raindrop

传统的浏览器书签功能虽然方便&#xff0c;但在管理和分类上存在诸多局限。今天&#xff0c;我要向大家推荐一款功能强大的跨平台书签管理-Raindrop https://raindrop.io/ &#x1f4e2; 主要功能&#xff1a; 智能分类和标签管理 强大的搜索功能 跨平台支持 分享与协作 卡片式…

适用于 Windows的 5 个最佳 PDF 转 Word 转换器

PDF 文件是共享文档的首选格式&#xff0c;但是&#xff0c;此类文件存在限制&#xff0c;使其难以修改或编辑。因此&#xff0c;您可能会发现自己正在寻找一种将 PDF 文件转换为 Word 或其他可编辑格式的方法。 有许多不同的 PDF 转换器&#xff0c;每个转换器的功能略有不同…

数据结构初阶 遍历二叉树问题(一)

一. 链式二叉树的实现 1. 结构体代码 typedef int BTDateType; typedef struct BinaryTreeNode {BTDateType data;struct BinaryTreeNode* left;struct BinaryTreeNode* right; }BTNode; 大概的图形是这样子 2. 增删查改 我们这里要明确的一点的 二叉树的增删查改是没有意…

04.ffmpeg打印音视频媒体信息

目录 1、相关头文件 2、相关结构体 3、相关函数 4、函数详解 5、源码附上 1、相关头文件 #include <libavformat/avformat.h> 包含格式相关的函数和数据结构 #include <libavutil/avutil.h> 包含一些通用实用函数 2、相关结构体 AV…

【HICE】转发服务器实验

1.在本地主机上操作 2.在客户端操作设置主机的IP地址为dns 3.测试,客户机是否能ping通

基于SpringBoot的招聘信息管理系统的详细设计和实现(源码+lw+部署文档+讲解等,欢迎咨询我!!)

文章目录 目录 文章目录 详细视频展示&#xff1a; 系统具体实现效果&#xff08;看看我的实力&#xff09; 技术栈&#xff08;详细的描述提供给同学思路参考&#xff09; 2.1 Java语言介绍 2.2 B/S架构 2.3 MySQL 数据库介绍 2.4 MySQL环境配置 2.5 SpringBoot框…

ASP.NET Core----基础学习02----中间件的执行顺序 静态文件中间件

文章目录 1.终端中间件&#xff08;Middleware&#xff09;2.中间件的执行顺序&#xff08;1&#xff09;当只有2个中间件的时候&#xff0c;先执行普通中间件&#xff0c;再执行终端中间件&#xff08;2&#xff09;当有多个中间件的时候&#xff0c;中间件的执行顺序 3.添加静…

【ARMv8/v9 GIC 系列 1.5 -- Enabling the distribution of interrupts】

请阅读【ARM GICv3/v4 实战学习 】 文章目录 Enabling the distribution of interruptsGIC Distributor 中断组分发控制CPU Interface 中断组分发控制Physical LPIs 的启用Summary Enabling the distribution of interrupts 在ARM GICv3和GICv4体系结构中&#xff0c;中断分发…