[Soul 源碼之旅] 1.8.6 Soul插件初體驗 (Hystrix 2)

在講 Hystrix 插件前,我們需要先了解一下 Hystrix 的具體實現,Hystrix 限流框架基于 大名鼎鼎的 RxJava 實現,我們這節先來了解一下 RxJava。

1.8.6.1 響應式編程

響應式編程簡稱 FRP (Function Reatcive Programing)詳細定義大家可以看一下 stackOverFlow 的這位大神解釋,簡單來說他就是一種基于事件的模型,我們需要知道某個事件是否發生有兩種方式,一種就是主動輪訓,我們把它稱為 Proactive 方式。另一種就是被動接收反饋,我們稱為 Reactive
響應式編程是未來的一種趨勢,對于后端java 程序員關于響應式編程第一個應該會想到 Spring 5 引入的 WebFlux ,而在 Android 中,響應式編程發展卻快得多,最主要原因是使用場景,Android 客戶端中存在大量的和服務器交互的程序,所以存在大量的異步回掉過程,一般這種請看就會使用到 RxJava ,它可以更加簡化代碼的邏輯。

1.8.6.2 Rxjava 使用入門

我們先來看一下一個RxJava 調用的實例:

//創建被觀察者
        Observable<String> observable = Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                subscriber.onNext("111");
                subscriber.onNext("222");
                subscriber.onNext("333");
                subscriber.onCompleted();
                
            }
        });
        //創建觀察者
        Observer<String> observer = new Observer<String>() {

            @Override
            public void onCompleted() {
                System.out.println("Complete");
            }

            @Override
            public void onError(Throwable e) {
                e.printStackTrace();
            }

            @Override
            public void onNext(String s) {
                System.out.println(s);
            }
        };
        //注冊,將觀察者和被觀察者關聯,將會觸發OnSubscribe.call方法
        observable.subscribe(observer);

我們先來介紹一下 RxJava 最重要的兩個成員:

  • Observable 可以理解為被觀察者,RxJava 中使用了觀察者模式。
  • Observer 可以理解為觀察者。
    Observable 方法
  • call 即被觀察者的所有活動,這里可以調用 subscriber.onNext 向訂閱者發送消息。
  • subscribe 這個是所有方法的啟動源頭,我將其主要邏輯整理如下,首先他會調用 Observerstart方法,告訴它開始了,然后調用自己的 call 方法,假如發生異常,就調用 subscriberonError 方法,然后 unsubscribed , 也就是將被觀察者注冊的觀察者清空。
    static <T> Subscription subscribe(Subscriber<? super T> subscriber, Observable<T> observable) {
        subscriber.onStart();
        try {
            RxJavaHooks.onObservableStart(observable, observable.onSubscribe).call(subscriber);
            return RxJavaHooks.onObservableReturn(subscriber);
        } catch (Throwable e) {
             subscriber.onError(RxJavaHooks.onObservableError(e));
            return Subscriptions.unsubscribed();
        }
    }

接下來我們說一下 observer 的三個方法:

  • onCompletedObservable 的 call 完成后調用,它后 onError 只有一個會被調用
  • onError 我們可以參考上面的源碼,在 調用 call 異常時調用
  • onNext Observable 每個發生時間都會調用。

1.8.6.3 Rxjava 各種操作

  • Schedule 調度線程
    我們將我們的代碼稍微改一下
        final CountDownLatch latch = new CountDownLatch(1);
        //創建被觀察者
        Observable<String> observable = Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                subscriber.onNext("111");
                subscriber.onNext("222");
                subscriber.onNext("333");
                subscriber.onCompleted();
                System.out.println(Thread.currentThread().getName());
            }
        });
        //創建觀察者
        Observer<String> observer = new Observer<String>() {

            @Override
            public void onCompleted() {
                System.out.println(Thread.currentThread().getName() + "-Complete");
                latch.countDown();
            }

            @Override
            public void onError(Throwable e) {
                e.printStackTrace();
            }

            @Override
            public void onNext(String s) {
                System.out.println(Thread.currentThread().getName() + "-" +s);
            }
        };
        //注冊,將觀察者和被觀察者關聯,將會觸發OnSubscribe.call方法
        observable.subscribeOn(Schedulers.newThread()) // 指定 subscribe() 發生在新的線程
            .observeOn(Schedulers.newThread()).subscribe(observer);
        latch.await();

得到結果入下:

RxNewThreadScheduler-2
RxNewThreadScheduler-1-111
RxNewThreadScheduler-1-222
RxNewThreadScheduler-1-333
RxNewThreadScheduler-1-Complete

這對于我們來說確實是很酷的事情,這里subscribeOnobserveOn 分別指定了我們生產者在調用 call 的線程和消費者的線程。

  • map 轉換
    map

    我們可以參考如上面的圖和下面的代碼,假如 observable 發射的是 Integer 類型,而 Obsever 需要接收 String 那么我們就可以通過 map 進行轉換。
   observable.subscribeOn(Schedulers.newThread()) 
            .observeOn(Schedulers.newThread()).map(i -> i +"").subscribe(observer);
  • flatmap
    flatmap 對于很多新手來說是最難理解的,flat 可以理解為平鋪,我們需要將 Observable 發射的時間平鋪開來的場景,如我們需要將 Stirng 使用空格分割成一個個單詞進行消費,如下:
 observable.subscribeOn(Schedulers.newThread()) 
            .observeOn(Schedulers.newThread()).flatMap(s -> Observable.from(s.split(" "))).subscribe(observer);

我們也可以參考圖片,我們這里將一個OnNext 事件轉為一個 Observable 然后將這些 Observable 匯總成一個 ObservableObsever 進行消費。

flatmpa

  • from 如上,我們可以通過from 將一個數組快速轉為 Observable 。
  • filter 顧名思義,就是將一部分事件過濾掉,這里很多操作和 stream 是類似的。
  • distinct 去重。

1.8.6.4 總結

我們這次只是簡單地學習了一下 RxJava 的原理,RxJava 還有很多好玩的地方等著我們去探索,有興趣的小伙伴可以深入學習一下,非常適合入門響應式編程,我們下一節將接收 Hystrix 如何通過 RxJava 實現降級和熔斷。

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,030評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,310評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 175,951評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,796評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,566評論 6 407
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,055評論 1 322
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,142評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,303評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,799評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,683評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,899評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,409評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,135評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,520評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,757評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,528評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,844評論 2 372

推薦閱讀更多精彩內容