java面试题 --- Spring③
2023-06-13 09:13:26 时间
1. 什么是 SpringCloud Alibaba?
- 阿里巴巴推出的一套微服务解决方案,主要提供了 nacos,sentinel 和 seata。
2. nacos 有什么作用?
- nacos 可以用来做注册中心和配置中心。它需要我们下载安装 nacos server,启动后访问 ip 加上 8848/nacos 即可访问其图形界面。支持 CPA 理论中的 AP 和 CP,可以自行选择。在项目中,引入 nacos 相关依赖然后进行相关配置就可以使用了。
3. 怎么保证 nacos 的高可用?
- nacos 做集群,nacos 的集群架构就是提供一个统一对外的虚拟 ip,然后这个 ip 再将请求分发到各个 nacos 节点上。我们一般用 nginx 来做 nacos 的集群,首先对 nacos 进行配置,拷贝 nacos 的 cluster.conf.example 文件,改名为 cluster.conf,然后在此文件中配置各个 nacos 节点的 ip 和对应端口;接着修改 nacos 的 startup.sh,使其能指定端口启动;最后修改 nginx 的 conf 文件,对流量进行分发,比如对外提供的是 80 端口,然后将 80 端口的流量分发到刚才配置的那几台 nacos 中。
4. nacos 中写的配置更新了,项目中要怎么获取到最新的配置?
- 获取配置的类加上 @RefreshScope 注解,就可以自动刷新了。
5. 如何保证 nacos 中配置的可靠性?
- 进行持久化,在 nacos 的 application.properties 文件中配置数据源,然后在 MySQL 中新建 nacos_config 数据库,在数据库中执行 nacos 提供的脚本,重启 nacos 后,nacos 中新增的配置就会出现在 config_info 表中。
6. sentinel 用来做什么?
- 服务熔断降级,配置限流规则。它可以和 nacos 一起使用,把规则都配置进 nacos,只要 nacos 做了持久化,就相当于 sentinel 也做了持久化。
7. 说一说分布式事务的实现方案。
- 我们用的是 seata,下载seata,然后注册进 nacos,用 MySQL 持久化,在项目中引入相关依赖,用 seata 对数据源进行代理,在需要加分布式事务的方法或类加上 @Global Transaction 注解即可。
8. 对 seata 的原理了解吗?
- seata 的核心就是三个组件加一个 ID。一个 ID 是指全局事务的 ID,三个组件是事务管理者,就是加了全局事务注解的方法;事务协调者,就是安装的 seata 组件;资源管理器,就是数据库。加了全局事务注解的方法向 seata 申请开启一个全局事务,seata 就会返回一个全局事务 ID在微服务调用链路中传播;数据库向 seata 注册分支事务,将其纳入到全局事务 ID 的管辖中;加了注解的方法发起对全局事务的提交或者回滚,然后 seata 再告诉数据库对事务进行提交或者回滚。
9. seata 的 AT 模式如何做到对业务无侵入的?
- 使用了两阶段提交协议。首先 seata 会拦截业务 SQL,将更新前的数据保存为 before image,然后执行 SQL 更新数据,再将更新后的数据保存为 after image,同时会生成行锁;如果顺利,二阶段就提交事务,删除 before image 和 after image 以及行锁;如果二阶段要回滚,首先会比较当前数据和 after image 是否一致,如果一致,将其还原成 before image,否则就是异常情况,人工处理。
相关文章
- JDK 19 / Java 19 正式发布,虚拟线程来了!
- 面试:精通Java;面试官:来讲一下JVM虚拟机内存模型的最底层原理,必须说详细说清楚,知其所以然。看完后,你还敢在简历上写精通Java吗?
- java高级工程师面试情景题_Java高级工程师面试题III
- java数组的声明_Java数组定义常用方法[通俗易懂]
- java calendar计算时间差_Java Calendar 计算时间差
- eclipse怎么导入java文件_Eclipse如何导入JAVA工程?如何将项目导入Eclipse中?
- java集合类面试题_Java集合类相关面试题
- java常量有哪些_Java中的常量有哪些?
- java 中高级面试题_Java中高级面试题
- n皇后问题 回溯法java_Java解决N皇后问题
- Java集合面试题_java是什么
- java mutator,Java – 使用Accessor和Mutator方法「建议收藏」
- JAVA遍历数组的三种方法_java遍历object数组
- 贼 TM 好用的 Java 工具类库
- 【Java】Best coding practices every java developer should
- Spring Boot 2.5.5发布:开始支持Java 17了!
- 【愚公系列】2023年04月 Java教学课程 134-Spring框架的事务
- mongodb运维_动力节点Java学院整理
- Java 图片合并类详解编程语言
- 五大JAVA Web框架的优缺点对比Spring MVC领先详解编程语言
- Java 获取当前年 、当前月详解编程语言
- 使用Java操作Redis数据库(java中使用redis)
- 连接高效完成Java面试:掌握Oracle连接知识(java面试oracle)
- 控制实现Java应用程序基于Redis的过期控制(redisjava过期)
- 数据库Java查询Oracle数据库:一种快捷、可靠的解决方案(java查询oracle)
- Java在Linux下的路径探索(javalinux路径)
- 通往成功的道路通过Java考证Oracle获取更高的成就(java考证oracle)
- 收购Oracle收购Java重新定义软件开发未来(java被oracle)
- Java 离开 Oracle,新的旅程即将开始(java没有Oracle)
- java中通用的线程池实例代码