rpc之hessian閑聊

參考鏈接

參考鏈接

前言

   在開源世界中有很多優(yōu)秀的RPC框架,如gRpc,Dubbo,Motan等等,但在某些場景下,此類框架就顯得"太重",Spring全家桶是java程序猿的最愛,在rpc方面對多種模型提供了支持,如Hessisan,Burlap以及Http invoker。今天想聊一聊的是基于Spring的輕量級的RPC實現---Hessian捐腿。

  Hessian是一種基于Http的輕量級遠程服務解決方案,利用二進制消息進行客戶端和服務端的交互,采用Servlet暴露服務乔宿。因它的二進制消息可以移植到其他非java語言中,具有跨語言特性。

Spring對RPC的支持及調用模型

  • 不管選擇哪種遠程調用模型,在spring中都提供了風格一致的支持(通常是由一個代理工廠bean實現),如下圖访雪。

Hessian服務發(fā)布與調用

模塊架構

QQ截圖20180826110043.png
  • sb-hessian-client 服務接口定義

  • sb-hessian-consumer 服務調用方

  • sb-hessian-provider 服務提供方

服務接口定義


public interface HelloService {

    String sayHello(String word);

}

服務實現與暴露

  • 服務實現

> /**
> 
>  * 服務實現
> 
>  */
> 
> @Component("helloService")
> 
> public class HelloServiceImpl implements HelloService,Serializable {
> 
>     @Override
> 
>     public String sayHello(String word) {
> 
>         return "hessian" + word;
> 
>     }
> 
> }

  • 服務暴露

   /**

     * 服務暴露

     * @param helloService

     * @return

     */

    @Bean(name = "/helloService.service")

    public HessianServiceExporter exportService(@Autowired HelloService helloService) {

        HessianServiceExporter exporter = new HessianServiceExporter();

        exporter.setService(helloService);

        exporter.setServiceInterface(HelloService.class);

        return exporter;

    }

  • 服務調用

    /**

     * 外部依賴服務

     *

     * @return

     */

    @Bean(name = "helloService")

    public HessianProxyFactoryBean getHelloService() {

        HessianProxyFactoryBean proxy = new HessianProxyFactoryBean();

        proxy.setServiceUrl("http://localhost:8083/helloService.service");

        proxy.setServiceInterface(HelloService.class);

        return proxy;

    }

注意

  • hessian是基于二進制的消息,在服務實現必須實現序列化接口详瑞。

  • 關于HessianServiceExporter

    HessianServiceExporter本質上是一個SpringMVC控制器。它通過接收Hessian請求,并把其轉換成對應的bean方法調用臣缀。

    由setService()和setServiceInterface()暴露服務蛤虐。

  • 關于HessianProxyFactoryBean

    通過setServiceUrl()和setServiceInterface()獲取服務調用

    
    

setServiceUrl("http://localhost:8083/helloService.service");


 注意這里需要指定的服務提供端的端口

> 項目示例鏈接

[鏈接](https://gitee.com/lingluojun/sb-rpc-parent.git)
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市肝陪,隨后出現的幾起案子,更是在濱河造成了極大的恐慌刑顺,老刑警劉巖氯窍,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異蹲堂,居然都是意外死亡狼讨,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門柒竞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來政供,“玉大人,你說我怎么就攤上這事〔几簦” “怎么了离陶?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長衅檀。 經常有香客問我招刨,道長,這世上最難降的妖魔是什么哀军? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任沉眶,我火速辦了婚禮,結果婚禮上杉适,老公的妹妹穿的比我還像新娘谎倔。我一直安慰自己,他們只是感情好猿推,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布片习。 她就那樣靜靜地躺著,像睡著了一般彤守。 火紅的嫁衣襯著肌膚如雪毯侦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天具垫,我揣著相機與錄音侈离,去河邊找鬼。 笑死筝蚕,一個胖子當著我的面吹牛卦碾,可吹牛的內容都是我干的。 我是一名探鬼主播起宽,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼洲胖,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了坯沪?” 一聲冷哼從身側響起绿映,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎腐晾,沒想到半個月后叉弦,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡藻糖,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年淹冰,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片巨柒。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡樱拴,死狀恐怖柠衍,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情晶乔,我是刑警寧澤珍坊,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站瘪弓,受9級特大地震影響垫蛆,放射性物質發(fā)生泄漏。R本人自食惡果不足惜腺怯,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一袱饭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧呛占,春花似錦虑乖、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至帜篇,卻和暖如春糙捺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背笙隙。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工洪灯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人竟痰。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓签钩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親坏快。 傳聞我的和親對象是個殘疾皇子铅檩,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現莽鸿,斷路器昧旨,智...
    卡卡羅2017閱讀 134,667評論 18 139
  • 1.1 spring IoC容器和beans的簡介 Spring 框架的最核心基礎的功能是IoC(控制反轉)容器,...
    simoscode閱讀 6,717評論 2 22
  • Spring Boot 參考指南 介紹 轉載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,823評論 6 342
  • 1.1 Spring IoC容器和bean簡介 本章介紹了Spring Framework實現的控制反轉(IoC)...
    起名真是難閱讀 2,584評論 0 8
  • 昨天從格爾木出發(fā)祥得,奔唐古拉山鎮(zhèn)兔沃。后半段開始出現高反,總覺得眼珠子要滾出來啃沪,實在沒有精力再寫,更新中斷了窄锅,也挺好创千,為...
    塵羊閱讀 196評論 0 1