1. 程式人生 > >Java同步、異步區別

Java同步、異步區別

消息 mysq redis 告訴 就是 java 大量 快速 nbsp

一、概念:

1.同步:所有的操作都做完,才返回給用戶。這樣用戶在線等待的時間太長,給用戶一種卡死了的感覺(就是系統遷移中,點擊了遷移,界面就不動了,但是程序還在執行,卡死了的感覺)。這種情況下,用戶不能關閉界面,如果關閉了,即遷移程序就中斷了。

2.異步:將用戶請求放入消息隊列,並反饋給用戶,系統遷移程序已經啟動,你可以關閉瀏覽器了。然後程序再慢慢地去寫入數據庫去。這就是異步。但是用戶沒有卡死的感覺,會告訴你,你的請求系統已經響應了。你可以關閉界面了。

同步,是所有的操作都做完,才返回給用戶結果。即寫完數據庫之後,在相應用戶,用戶體驗不好。

異步,不用等所有操作等做完,就相應用戶請求。即先相應用戶請求,然後慢慢去寫數據庫,用戶體驗較好。

二、同步異步操作例子:

1.同步:

比如銀行的轉賬系統,對數據庫的保存操作等等都是使用同步交互操作。

2.異步:

為了避免短時間大量的數據庫操作,就使用緩存機制,也就是消息隊列。先將數據放入消息隊列,然後再慢慢寫入數據庫。

引入消息隊列機制,雖然可以保證用戶請求的快速響應,但是並沒有使得我數據遷移的時間變短(即80萬條數據寫入mysql需要1個小時,用了redis之後,還是需要1個小時,只是保證用戶的請求的快速響應。用戶輸入完http url請求之後,就可以把瀏覽器關閉了,幹別的去了。如果不用redis,瀏覽器不能關閉)。

Java同步、異步區別