java面试题 --- Spring③

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,否则就是异常情况,人工处理。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,682评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,277评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,083评论 0 355
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,763评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,785评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,624评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,358评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,261评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,722评论 1 315
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,900评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,030评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,737评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,360评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,941评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,057评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,237评论 3 371
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,976评论 2 355

推荐阅读更多精彩内容