soul从入门到放弃4--sofa-rpc代理

零、sofa-rpc简介

sofa-rpc扫盲贴:https://www.jianshu.com/p/d986dd9b1e63

蚂蚁金服开源的分布式rpc框架,跟dubbo很像的用法

image

一、添加sofa插件及相关操作

  • soul-admin --> 插件管理-> sofa 设置为开启。
image
  • 在sofa插件的配置中,配置如下:配置sofa的注册中心。
image
  • 每一个sofa接口方法,都会对应一条元数据,可以在 soul-admin -->元数据管理,进行查看。
image
  • 路径:就是你http请求的路径。
  • rpc扩展参数,对应为sofa接口的一些配置,调整的话,请在这里修改,支持json格式,以下字段:

<pre>{"loadbalance":"hash","retries":3,"timeout":-1}</pre>

二、依赖引入

soul-bootstrap添加依赖

注意sofa版本与注册中心版本

<dependency>
           <groupId>com.alipay.sofa</groupId>
           <artifactId>sofa-rpc-all</artifactId>
           <version>5.7.6</version>
       </dependency>
       <dependency>
           <groupId>org.apache.curator</groupId>
           <artifactId>curator-client</artifactId>
           <version>4.0.1</version>
       </dependency>
       <dependency>
           <groupId>org.apache.curator</groupId>
           <artifactId>curator-framework</artifactId>
           <version>4.0.1</version>
       </dependency>
       <dependency>
           <groupId>org.apache.curator</groupId>
           <artifactId>curator-recipes</artifactId>
           <version>4.0.1</version>
       </dependency>
       <dependency>
           <groupId>org.dromara</groupId>
           <artifactId>soul-spring-boot-starter-plugin-sofa</artifactId>
           <version>${last.version}</version>
       </dependency>

sofa服务引入soul的client

  • springboot应用
      <dependency>
           <groupId>org.dromara</groupId>
           <artifactId>soul-spring-boot-starter-client-sofa</artifactId>
           <version>${soul.version}</version>
       </dependency>

yml中添加配置

soul:
       sofa:
         adminUrl: http://localhost:9095
         contextPath: /sofa
         appName: sofa
      # adminUrl: 为你启动的soul-admin 项目的ip + 端口,注意要加 http://
      # contextPath: 为你的这个项目在soul网关的路由前缀,这个你应该懂意思把? 比如/order ,/product 等等,网关会根据你的这个前缀来进行路由.
      # appName:你的应用名称,不配置的话,会默认取sofa配置中application 中的名称</pre>
  • springmvc应用
      <dependency>
           <groupId>org.dromara</groupId>
           <artifactId>soul-client-sofa</artifactId>
           <version>${project.version}</version>
       </dependency>

bean中xml添加配置

  <bean id ="sofaServiceBeanPostProcessor" class ="org.dromara.soul.client.sofa.SofaServiceBeanPostProcessor">
           <constructor-arg  ref="sofaConfig"/>
      </bean>
      <bean id="sofaConfig" class="org.dromara.soul.client.sofa.common.config.SofaConfig">
           <property name="adminUrl" value="http://localhost:9095"/>
           <property name="contextPath" value="/你的contextPath"/>
           <property name="appName" value="你的名字"/>
      </bean>

三、调用参数的说明

  • 注册

通过在方法上使用@SoulSofaClient 注解,将方法注册到soul-admin

image
  • 启动你的提供者,输出日志 sofa client register success 大功告成
image
  • 参数调用基本和dubbo类似此处不赘述,只是简单调用下验证好使
image

四、浅入浅出探究@SoulSofaClient 注解如何注册到soul-admin

  • 从soul-examples/soul-examples-sofa/pom.xml入手,最为可疑的jar是
<dependency>
    <groupId>org.dromara</groupId>
    <artifactId>soul-spring-boot-starter-client-sofa</artifactId>
    <version>${soul.version}</version>
    <exclusions>
        <exclusion>
            <artifactId>guava</artifactId>
            <groupId>com.google.guava</groupId>
        </exclusion>
    </exclusions>
</dependency>
  • 进入soul-spring-boot-starter-client-sofa项目中发现spring.factories

spring.factories科普贴:https://www.cnblogs.com/huanghzm/p/12217630.html

image
  • 进入SoulSofaClientConfiguration一探究竟
image
  • 进入SofaServiceBeanPostProcessor再探究竟,此方法实现了BeanPostProcessor

BeanPostProcessor科普贴:https://www.jianshu.com/p/369a54201943

https://blog.csdn.net/qq_38526573/article/details/88086752

构造方法中创建了线程池,赋值了sofaConfig(配置信息)、url(注册地址)

image

在postProcessAfterInitialization中,也就是bean实例化后,基于线程池发起对配置信息的注册

image

在handler中,主要是将有@SoulSofaClient注解的方法注册到soul-admin上

image

五、心得与体会

  • 经常写业务代码,好多学到的知识不能应用,忘的贼拉拉的快啊。通过一个注册小模块,使用大佬们传授的断点+猜想法 也算是理顺了流程。满足好奇的同时,复习不少之前学习spring的知识。
  • 日拱一卒,每天进步一点点
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容