java面试说自己的优势,2022必看

纯手打“RocketMQ笔记”

第一节:RocketMQ介绍

  • 1.1 核心概念(主题、生产者、消费者、消息)

  • 1.2 RocketMQ的设计理念和目标(设计理念、设计目标)

image

第二节:RocketMQ中消息的发送

  • 2.1 单向[OneWay]发送(代码演示、Producer Group、Producer实例、Message Key、Tag)

  • 2.2 可靠同步发送(代码演示、Message ID、SendStatus、Queue)

  • 2.3 可靠异步发送(代码演示)

  • 2.4 RocketMQ中消息发送的权衡

image

第三节:RocketMQ消息消费

  • 3.1 集群消息和广播消费(基本概念)

  • 3.2 场景对比(集群消息模式、广播消息模式、使用集群模式模拟广播)

  • 3.3 消费方式(推模式、拉模式)

image

第四节:深入消息发送

  • 4.1 消息生产者流程

  • 4.2 批量消息发送

  • 4.3 消息重试机制(规避原则)

image

第五节:深入消息模式

  • 5.1 拉模式

  • 5.2 推模式(长轮询、流量控制、消息队列负载与重新分布机制、消息确认、消息进度存储、推模式总结)

第六节:顺序消息

  • 6.1 全局顺序消息(适用场景、示例)

  • 6.2 部分顺序消息

第七节:延时消息

  • 7.1 概念介绍

  • 7.2 适用场景

  • 7.3 使用方式

image

第八节:死信队列

  • 8.1 概念介绍

  • 8.2 适用场景(死信消息的特性、死信队列的特性)

第九节:消费幂等

  • 9.1 什么是消费幂等

  • 9.2 需要处理的场景

  • 9.3 处理方法

第十节:消息过滤

  • 10.1 概念介绍

  • 10.2 表达式过滤

  • 10.3 类过滤

第十一节:RocketMQ存储结构概要设计

  • 11.1 消息存储结构(CommitLog、ConsumeQueue、IndexFile、Config、其他)

  • 11.2 内存映射

  • 11.3 文件刷盘机制(异步刷盘方式、同步刷盘方式、总结)

  • 11.4 过期文件删除(过期判断、删除条件)

image

第十二节:RocketMQ中的事务消息

  • 12.1 事务消息实现思想

  • 12.2 两阶段提交

  • 12.3 事务状态回查机制

  • 12.4 代码实现

image

第十三节:RocketMQ主从同步(HA)机制

  • 13.1 RocketMQ集群部署模式(集群部署模式:单master模式、多master模式、多master多Slave异步复制模式、多master多slave同步双写模式、多主模式与数据重复;安装部署过程)

  • 13.2 主从复制原理

  • 13.3 读写分离机制

  • 13.4 与Spring集成(Pom文件、生产者、消费者)

  • 13.5 与SpringBoot集成

image

第14节:限时订单实战

  • 14.1 什么是限时订单

  • 14.2 如何实现限时订单(限时订单的流程、限时订单实现的关键、轮询数据库、Java本身的提供的解决方案、从系统可用性角度考虑、从系统伸缩性角度考虑)

  • 14.3 用RocketMQ实现限时订单(延时消息:概念介绍、适用场景;核心的代码部分)

image

第十五节:RocketMQ源码分析

  • 15.1 RocketMQ整体架构

  • 15.2 NameServer

  • 15.3 RocketMQ服务启动

  • 15.4 源码分析之消息的来龙去脉(消息的生产:Client中的消息发送、Broker中消息的生产、Broker中更新消息队列和索引文件;消息的消费:Client中的消息者启动流程、消息的拉取、消息的消费)

image

最后

关于面试刷题也是有方法可言的,建议最好是按照专题来进行,然后由基础到高级,由浅入深来,效果会更好。当然,这些内容我也全部整理在一份pdf文档内,分成了以下几大专题:

  • Java基础部分

  • 算法与编程

  • 数据库部分

  • 流行的框架与新技术(Spring+SpringCloud+SpringCloudAlibaba)

这份面试文档当然不止这些内容,实际上像JVM、设计模式、ZK、MQ、数据结构等其他部分的面试内容均有涉及,因为文章篇幅,就不全部在这里阐述了。

作为一名程序员,阶段性的学习是必不可少的,而且需要保持一定的持续性,这次在这个阶段内,我对一些重点的知识点进行了系统的复习,一方面巩固了自己的基础,另一方面也提升了自己的知识广度和深度。

份面试文档当然不止这些内容,实际上像JVM、设计模式、ZK、MQ、数据结构等其他部分的面试内容均有涉及,因为文章篇幅,就不全部在这里阐述了。

作为一名程序员,阶段性的学习是必不可少的,而且需要保持一定的持续性,这次在这个阶段内,我对一些重点的知识点进行了系统的复习,一方面巩固了自己的基础,另一方面也提升了自己的知识广度和深度。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

k8s service的概念以及创建方法

Service 的功能: Service主要用于提供网络服务,通过Service的定义,能够为客户端应用提供稳定的访问地址(域名或IP地址)和负载均衡功能,以及屏蔽后端Endpoint的变化,是K8s实现微服务的核心资源。…

高防IP简介

高防IP可以防御的有包括但不限于以下类型: SYN Flood、UDP Flood、ICMP Flood、IGMP Flood、ACK Flood、Ping Sweep 等攻击。高防IP专注于解决云外业务遭受大流量DDoS攻击的防护服务。支持网站和非网站类业务的DDoS、CC防护,用户通过配置转发规则&#x…

虚拟机安装+固定ip地址

一、下载CentOS 二、安装CentOS 1、打开你的VMware Workstation Pro,并点击“创建新的虚拟机” 2、点选典型(推荐)(T),并点击“下一步” 3、点选稍后安装操作系统(S),并点击“下一步” 4、点选Linux,并点击“下一步” 6、点击“…

Retrofit核心原理

Retrofit是一个类型安全的HTTP客户端库,广泛用于Android和Java应用中,用于简化网络请求和响应的处理。本文将深入探讨Retrofit的核心原理,帮助开发者理解其背后的工作机制。 Retrofit简介 Retrofit是Square公司开发的一个开源库&#xff0c…

Jenkins配置在远程服务器上执行shell脚本

Jenkins配置在远程服务器上执行shell脚本 说明:Jenkins部署在ServerA:10.1.1.74上,要运行的程序在ServerB:10.1.1.196 分两步 第一步:Linux Centos7配置SSH免密登录 Linux Centos7配置SSH免密登录-CSDN博客 第二步…

MySql出现无法正常启动(0x000007b)的快速解决

目录 1.背景介绍 2.解决方案 1.背景介绍 昨天在清理电脑内存空间的时候,不小心将一些重要的系统组件删除,导致无法正常启动mysql,一开始是提示经过msvcp120.dll,于是找到下载dll的网站将组件补充进system,但随后又提…

SpringMVC(2)

目录 SSM整合统一异常处理项目异常处理方案异常解决方案前后端协议联调拦截器 SSM整合 统一异常处理 异常的种类及出现异常的原因: 框架内部抛出的异常:因使用不合规导致数据层抛出的异常:因外部服务器故障导致(例如:服务器访问超…

疫情物资智能管理:Java与SpringBoot的实践

✍✍计算机毕业编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java、…

如何进行写作的刻意练习

写作从来不可能一蹴而就,而是一件需要我们持续坚持、努力的事情。 人如果没有目标就会迷失方向, 既然需要长期的坚持,就需要我们根据自身情况制定每一阶段的目标。 目标的制定要清晰可达,不能模棱两可,要认证对待。 …

Py2neo查询neo4j周杰伦数据库中的节点、关系和路径教程

文章目录 py2neo介绍连接Neo4j数据库py2neo查询图数据库neo4j数据概览使用NodeMatcher查询节点使用RelationshipMatcher查询关系 通过执行Cypher语句查询 py2neo介绍 Neo4j是一款开源图数据库,Py2neo提供了使用Python语言访问Neo4j的接口。本文介绍了使用Py2neo的N…

Python学习 day05(异常、模块导入、包)

异常 为什么要捕获异常 当程序遇到了BUG,如果不对BUG进行手动捕获,那么整个程序就会因为一个BUG而停止运行,这在有些情况下是会造成很大的损失,但是如果我们进行了手动捕获,那么整个程序会继续运行捕获异常的作用在于&…

第三百七十二回

文章目录 1. 概念介绍2. 实现方法2.1 maskFilter2.2 shader 3. 代码与效果3.1 示例代码3.2 运行效果 4. 内容总结 我们在上一章回中介绍了"两种阴影效果"相关的内容,本章回中将介绍如何绘制阴影效果.闲话休提,让我们一起Talk Flutter吧。 1. 概…