問題的引出: 傳統的OOP程序經常表現出一些不自然的現象,核心業務中總摻雜着一些不相關聯的特殊業務,如日志記錄,權限驗證,事務控制,性能檢測,錯誤信息檢測等等,這些特殊業務可以說和核心業務沒有根本上 ...
volatile是java語言中的一個關鍵字,常用於並發編程,有兩個重要的特點:具有可見性,java虛擬機實現會為其滿足Happens before原則 不具備原子性.用法是修飾變量,如:volatile int i. volatile原理 介紹其可見性先從cpu,cpu緩存和內存的關系入手. cpu緩存是一種加速手段,cpu查找數據時會先從緩存中查找,如果不存在會從內存中查找,所以如果緩存中數據 ...
2018-07-29 14:58 0 890 推薦指數:
問題的引出: 傳統的OOP程序經常表現出一些不自然的現象,核心業務中總摻雜着一些不相關聯的特殊業務,如日志記錄,權限驗證,事務控制,性能檢測,錯誤信息檢測等等,這些特殊業務可以說和核心業務沒有根本上 ...
Mycat原理 Mycat的原理並不復雜,復雜的是代碼,如果代碼也不復雜,那么早就成為一個傳說了。Mycat的原理中最重要的一個動詞是“攔截”,它攔截了用戶發送過來的SQL語句,首先對SQL語句做了一些特定的分析:如分片分析、路由分析、讀寫分離分析、緩存分析等,然后將此SQL發往后端的真實 ...
1.volatile最適用一個線程寫,多個線程讀的場合。 如果有多個線程並發寫操作,仍然需要使用鎖或者線程安全的容器或者原子變量來代替。(摘自Netty權威指南) 疑問:如果只是賦值的原子操作,是否可以多個線程寫?(答案:可以,但是一般沒有這樣的必要,即沒有這樣的應用場景 ...
介紹 把代碼塊聲明為 synchronized,有兩個重要后果,通常是指該代碼具有 原子性(atomicity)和 可見性(visibility)。 原子性意味着個時刻,只有一個線程能夠執行 ...
本博客系列是學習並發編程過程中的記錄總結。由於文章比較多,寫的時間也比較散,所以我整理了個目錄貼(傳送門),方便查閱。 並發編程系列博客傳送門 volatile是Java提供的一種輕量級的同步機制,在並發編程中,它也扮演着比較重要的角色。一個硬幣具有兩面,volatile不會造成 ...
Canal簡介 Canal是阿里開源的一款基於Mysql數據庫binlog的增量訂閱和消費組件,通過它可以訂閱數據庫的binlog日志,然后進行一些數據消費,如數據鏡像、數據異構、數據索引、緩 ...
Flume概念 Flume是一個分布式、可靠、和高可用的海量日志聚合的系統,支持在系統中定制各類數據發送方,用於收集數據;同時,Flume提供對數據進行簡單處理,並寫到各種數據接受方(可定制)的能 ...
上周末有幸參加了Alluxio(之前也叫Tachyon),七牛雲和示說網舉辦的Alluxio上海Meetup,之前我並沒有在真實應用場景中使用過Alluxio,對其適用的應用場景一直報懷疑態度。自信聆聽其創始人的演講之后,感覺這個項目還挺有意思,對Alluxio簡單總結一下 ...