互連網金融代表一種海量資料高事務高速處理

來源:互聯網
上載者:User

標籤:http   io   使用   java   ar   strong   資料   問題   cti   

 

我們知道分布式系統是一種橫向水平伸縮(Scalable)方案,業務決定架構,

不是所有的業務都能夠採取水平伸縮就能解決效能問題的,問題的關鍵還在於資料之間的關係的強弱。

資料結構是不是表達資料之間的關係的強弱?

請注意結構這個詞語,當你看到建築結構,看到你的房屋結構時,你對結構一詞可能有更深入理解,既然是結構了,預設資料之間已經是一種強關係。

結構化資料和非結構化資料才是完整表達資料之間關係的強弱。

也就是說,水平伸縮方案適合非結構化資料,也就是資料之間是弱關係甚至沒有關係,這是很容易理解的;但如果資料之間是一種強烈的結構關係,我們稱之為彙總,怎麼辦呢?

有一條電腦原理:彙總必然引發爭奪,道理很簡單:僧多粥少,坐地鐵人多就要搶位置。

對於爭奪,傳統軟體的思路就是用鎖,某個時刻只能允許一個使用者操作這個資源,其他使用者線程必須等待其操作完成,於是互連網並排歡樂奔跑的使用者到這裡被迫強行停下來,等待,聽從指揮,如果允許,將被喚醒進入操作。

這種人為強制性的管理措施顯然帶來了很差的使用者體驗,甚至崩潰,同時也是不尊重底層辛苦勞動的CPU。因為線程是CPU私人財產,你不能將之充公後再進行管理分配,活活地折磨CPU。

當前對於爭奪比較優雅的解決方案是Reactive編程,也就是事件驅動編程。

對於有著強烈關係的彙總資料,我們必須將其作為整體對象來處理,當發生多個並發使用者操作這個整體對象時,我們也不能使用鎖來對使用者進行限制。

參考Java的NIO的Reactor原理,以及Node.js的原理,我們為每個彙總對象分配一個專門的守護者,所有有關這個資源的操作都交給這個守護者操作,通過一個無鎖的隊列進行快速排隊與守護者進行交接。

通過Reactive編程,我們還可以避免某個資源的操作佔據CPU線程太久,只要做完有關資源爭奪的那點事情後就趕快另派線程做剩餘的事情。這樣將串列順序操作和並行操作能夠有機細膩度的完美結合在一起。

那麼效能的擴充如何解決呢?不能通過水平擴充,就只能通過垂直擴充,這裡的垂直擴充不一定是向上擴充,比如PC換小型機,而是一種向下擴充,通過增加CPU核心數來提升彙總資料的並發處理能力。

總之,互連網金融代表一種海量資料高事務高速處理,類似高頻交易,與前期12306 或光大事件一樣,對於我們從業務資料分析方法,一直到底層組件代碼編程實現,都會提出新的挑戰,產生顛覆性編程革命。

互連網金融代表一種海量資料高事務高速處理

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.