欢迎访问我的GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos

初识spring-cloud-square

  • 2021年4月13日,spring在官方博客上宣布,一个名为Spring Cloud Square的项目正式发布首个公开可用的里程碑版本:

  • 热门视频网站于2021年7月7日发布一段介绍Spring Cloud Square的视频,如下图,大佬Josh Long给我们演示了如何用Spring Cloud Square将SpringBoot应用的HTTP客户端做得更智能,B站搜索spring-cloud-square即可

  • 在介绍spring-cloud-square之前,咱们先去了解一下square,会对咱们后面的理解有很大帮助,网站是:https://square.github.io,如下图,这是个开源网站,向社区贡献了很多库,到底有哪些库呢?点击下图红框中的Java试试:

  • 如下图,Java库还真不少呢,红框中的两位:okhttp和retrofit,都是大名鼎鼎:

  • 至此,聪明的您应该猜到了:spring-cloud-square和上面提到的square有关,具体的说应该是和square的java库有关,例如将okhttp和retrofit与SpringBoot的自动装配结合,玩出点花样来

  • 另外关键字还有spring-cloud,再加上okhttp和retrofit都和网络访问有关,spring-cloud-square的身份就更具体了:借助square的库,方便Spring Cloud环境中的服务调用!

提前小结

  • 为避免因废话太多而被聪明的您抛弃,现在就小结什么是spring-cloud-square:
  1. spring-cloud-square的重点是集成
  2. Spring Cloud LoadBalance提供了根据服务名获取对应IP和端口的能力
  3. OkHttpClient和Retrofit是远程访问的框架
  4. Spring Cloud LoadBalance和OkHttpClient组合的话,在用OkHttpClient远程访问的时候可以用服务名做地址了,具体的IP和端口由Spring Cloud LoadBalance负责获取
  5. Spring Cloud LoadBalance和Retrofit组合,也是同样的道理
  6. 于是,Spring官方就推出了上述组合,用AutoConfig再加少量代码(例如OkHttpClient添加Interceptor,功能是将服务名替换成IP和端口),将上述关键技术做组合,再包装成jar,例如spring-cloud-square-okhttp.jar就是 Spring Cloud LoadBalancer与OkHttpClient的组合
  7. 咱们开发SpringBoot应用时,直接依赖spring-cloud-square-okhttp.jar,再添加少量代码(如Builder实例化),就能方便的远程调用了;
  8. 这种组合型jar包,Spring一口气做了三个,然后起个名字叫做spring-cloud-square,然后,您爱用哪个就用哪个
  9. 咱们开发SpringBoot应用时,直接依赖spring-cloud-square-okhttp.jar,再添加少量代码(如Builder实例化),就能方便的远程调用了;
  • 看到这里,聪明的您应该明白了,spring-cloud-square原来这么简单,只是将注册中心和和网络工具集成,为应用开发提供了一些辅助而已,实际上看过spring-cloud-square源码之后也确实如此,不过spring-cloud-square目前还只是孵化项目,由于Spring技术栈在不断演进,相信它会越来越符合官方的描述:Smart,做更智能的HTTP客户端

  • 接下来再看看spring-cloud-square提供的具体的能力有哪些

spring-cloud-square的具体能力

  • 如下图所示,spring-cloud-square一共有三种能力,下图每一个红色背景的节点代表一种具体的能力,稍后会详细说明:

  • okhttp类型容易理解,只有一个jar文件:spring-cloud-square-retrofit.jar,用在最简单的请求响应场景

  • retrofit的好处很多(简洁易用,解耦,扩展性强,可搭配多种Json解析框架(例如Gson),支持RxJava),就不在本文展开了,博览群书的您应该记得,retrofit无法独立完成网络操作,其底层还要依赖更加基础的库,这个特点在spring-cloud-square中也体现出来了:和okhttp搭配是常见的经典组合(安卓开发的同学一定很熟悉),或者和webflux搭配,用在响应式异步非阻塞场景;

  • 看到这里,聪明的您应该得出一个结论:欣宸废话太多...

  • 您说的没错,下一篇咱们进入实战环节,写代码体验spring-cloud-square,欣宸原创,必不会辜负您的期待

你不孤单,欣宸原创一路相伴

  1. Java系列
  2. Spring系列
  3. Docker系列
  4. kubernetes系列
  5. 数据库+中间件系列
  6. DevOps系列

欢迎关注公众号:程序员欣宸

微信搜索「程序员欣宸」,我是欣宸,期待与您一同畅游Java世界...

https://github.com/zq2599/blog_demos

五分钟搞懂spring-cloud-square的更多相关文章

  1. 五分钟搞懂POM设计模式

    转载请注明出处️ 作者:IT小学生蔡坨坨 原文链接:五分钟搞懂POM设计模式 大家好,我是IT小学生蔡坨坨. 今天,我们来聊聊Web UI自动化测试中的POM设计模式. 为什么要用POM设计模式 前期 ...

  2. 五分钟搞懂Vuex

    这段时间一直在用vue写项目,vuex在项目中也会依葫芦画瓢使用,但是总有一种朦朦胧胧的感觉.于是决定彻底搞懂它. 看了一下午的官方文档,以及资料,才发现vuex so easy! 作为一个圈子中的人 ...

  3. 五分钟搞懂 Linux 重点知识,傻瓜都能学会!

    来源:无痴迷,不成功 www.cnblogs.com/justmine/p/9053419.html 写在前面 我们都知道Linux是一个支持多用户.多任务的系统,这也是它最优秀的特性,即可能同时有很 ...

  4. 五分钟搞懂什么是B-树(全程图解)【转】

    前戏 我们大家都知道动态查找树能够提高查找效率,比如:二叉查找树,平衡二叉查找树,红黑树.他们查找效率的时间复杂度O(log2n),跟树的深度有关系,那么怎么样才能提高效率呢?当然最快捷的方式就是减少 ...

  5. 五分钟搞懂MySQL索引下推

    大家好,我是老三,今天分享一个小知识点--索引下推. 如果你在面试中,听到MySQL5.6"."索引优化" 之类的词语,你就要立马get到,这个问的是"索引下推 ...

  6. 不用找了,300 分钟帮你搞定 Spring Cloud!

    最近几年,微服务架构一跃成为 IT 领域炙手可热的话题,大量一线互联网公司因为庞大的业务体量和业务需求,纷纷投入了微服务架构的建设中,像阿里巴巴.百度.美团等大厂,很早就已经开始了微服务的实践和应用. ...

  7. 五分钟搞定Go.js

    五分钟搞定Go.js  1.基于html5~因为Go.js是一个依赖于HTML5特性的JavaScript库,所以需要确保您的页面声明它是一个HTML5文档,当然需要加载库 <!DOCTYPE ...

  8. zookeeper-架构设计与角色分工-《每日五分钟搞定大数据》

    本篇文章阅读时间5分钟左右 点击看<每日五分钟搞定大数据>完整思维导图   zookeeper作为一个分布式协调系统,很多组件都会依赖它,那么此时它的可用性就非常重要了,那么保证可用性的同 ...

  9. zookeeper核心-zab协议-《每日五分钟搞定大数据》

    上篇文章<paxos与一致性>说到zab是在paxos的基础上做了重要的改造,解决了一系列的问题,这一篇我们就来说下这个zab. zab协议的全称是ZooKeeper Atomic Bro ...

随机推荐

  1. python库--pandas--DataFrame

    转换    索引,迭代    运算符    功能应用,分组及窗口    计算/描述统计 重新索引/选择/标签操作    缺失数据处理    形状变换/排序/转置 组合/加入/合并    时间序列相关  ...

  2. MySQL中的查询事务问题

    之前帮同学做个app的后台,使用了MySQL+MyBatis,遇到了一个查询提交的问题,卡了很久,现在有时间了来复盘下 环境情况 假设有学生表: USE test; CREATE TABLE `stu ...

  3. webpack 安装与卸载

    全局安装(不推荐): npm install webpack webpack-cli -g 安装好后打印版本: webpack -v webpack-cli -v 卸载全局 npm uninstall ...

  4. Java基础系列(19)- Switch结构

    package struct; public class SwitchDemo01 { //case穿透 //switch 匹配一个具体的值 public static void main(Strin ...

  5. 字体小于12px 无法缩小解决方案

    通过缩放进行大小控制. 缩放可能会导致元素也进行缩放.需要注意 transform: scale(0.5);

  6. 关于我刚开始学习c语言的这档事

    关于我刚开始学习C语言的这档事 就在9月20日下午,记得王老师曾提及三类人,一类专注于自己内心的感受:一类人专注于探索与创造:还有一类专注于效率的最大化.思绪不禁回想到11号至今的学习过程-- 我的学 ...

  7. CF1322B-Present【双指针】

    正题 题目链接:https://www.luogu.com.cn/problem/CF1322B 题目大意 给出\(n\)个数字\(a_i\)求 \[\bigoplus _{i=1}^n\bigopl ...

  8. spring-data-redis 上百万的 QPS 压力太大连接失败,我 TM 人傻了

    大家好,我们最近业务量暴涨,导致我最近一直 TM 人傻了.前几天晚上,发现由于业务压力激增,某个核心微服务新扩容起来的几个实例,在不同程度上,出现了 Redis 连接失败的异常: org.spring ...

  9. webRTC中语音降噪模块ANS细节详解(一)

    ANS(adaptive noise suppression) 是webRTC中音频相关的核心模块之一,为众多公司所使用.从2015年开始,我在几个产品中使用了webRTC的3A(AEC/ANS/AG ...

  10. 从零入门 Serverless | 在线应用的 Serverless 实践

    作者 | 唐慧芬(黛忻) 阿里云产品专家 导读:毫无疑问,Serverless 能够在效率和成本上给用户带来巨大收益.那具体到落地又应该怎么做呢?本文就给大家详细解读 Serverless 的落地实践 ...