夢中驚醒 在Tomcat的線程池裡,有這樣一個線程,自打出生後,從來不去幹活兒,有好多次走出線程池“這座大山”去看世界的機會,都被他拱手讓給了弟兄們。弟兄們給他取了個名字叫二師兄。沒錯,好吃懶做,飽了睡,醒了吃。這不,又迷迷糊糊睡著了,還打呼嚕呢。“快起來,起來,幹活去了”,有人在喊他。只見二師兄轉 ...
夢中驚醒
在Tomcat的線程池裡,有這樣一個線程,自打出生後,從來不去幹活兒,有好多次走出線程池“這座大山”去看世界的機會,都被他拱手讓給了弟兄們。
弟兄們給他取了個名字叫二師兄。沒錯,好吃懶做,飽了睡,醒了吃。這不,又迷迷糊糊睡著了,還打呼嚕呢。
“快起來,起來,幹活去了”,有人在喊他。只見二師兄轉轉身,不耐煩道,“叫別人去,叫別人去”。
“哪還有別人呢”,突然聲音高了八度。二師兄覺得不對勁兒啊,轉身一看,原來是大管家親自來了,嚇得他趕緊跳起來向外跑去。
遠方來客
二師兄來到大門外,看到一眾人馬已在此等候,他哪見過這場面啊,心裡不免有些忐忑,強裝鎮定道,“你們領頭兒的是誰,出來自我介紹下吧”。
眼見三個人下了馬走上前來,第一位說道,“我是來自Spring家族的,叫Controller”。第二位說道,“我也是來自Spring家族,叫Service”。
“我是來自MyBatis家族,叫Mapper”,第三位說道,“我們結拜為異姓三兄弟,奉主人之命,前來執行任務”。
二師兄雖然沒“見過世面”,但是在睡不著時總聽弟兄們說起這些,嗯,是他們,準沒錯。“諸位都請下馬隨我來吧”。
大伙都跟著二師兄來到了Tomcat的大宅子的後院的西廂房的二堂里。二師兄招呼大家坐下,給他們端茶倒水,讓諸位稍作休息。
老大來到二師兄面前道,“我們此行的目的是要到資料庫山村進行交流學習,還請你做我們的嚮導,帶領大伙一同前往”。
二師兄自然沒去過資料庫山村,但聽說那裡地處深山老林,一路崎嶇陡峭,便不想帶他們去。於是就準備嚇唬嚇唬他們,讓他們自己打退堂鼓。
“資料庫山村著實遙遠,要翻過幾座大山,走上幾天幾夜,關鍵一到夜裡有豺狼虎豹出沒,還聽說繡花鞋都成精了,出來吃人啊”,二師兄道。
“不入虎穴,焉得虎子。我們兄弟既然來了,就不怕這些”,老二說道。“二哥說的對,我們不怕。來一個殺一個,來兩個殺一雙”,老三補充道。
二師兄一看這陣勢,不去是不行了,就藉故先出來了,去尋求幫助啊。
新式武器
一會兒功夫,只見二師兄咧著嘴、帶著標誌的憨笑向這邊跑來,一邊喊著,“三位哥哥,新式武器,新式武器,我們有救了,有救了”。
三兄弟一臉問號、有點莫名。老大道,“十八般兵器我們都帶了,莫非你說的是第十九種”?“快拿出來,讓我們見識見識”,老三接著道。
二師兄道,“這新式武器啊,它不是個兵器,是一種工具。其實事情原本是這樣的。。。”。三兄弟聽完二師兄的解說後明白了。
原來是Tomcat王府為了加強與周邊的聯繫,就趁著前幾天315的活動,在“五環外”的PDD上購買了“鄉村版”的無繩電話,正好資料庫山村也購買了,前幾天已經收到貨,調試好可以使用了。
“你們這次正好趕巧了,可以試試這個無繩電話,通過電話交流,不用再跑一趟了”,二師兄道。三兄弟只是聽說過,但從沒用過,有點迫不及待的想見見這“高科技”。
二師兄隨即帶領著大伙朝“機房”方向走去。
有點意思
大伙來到機房,看著無繩電話都很興奮,但是沒人會用,都望著二師兄。二師兄哪會用呢,只好翻箱倒櫃找出了說明書,可惜自己看不懂。
老二對著自己的管家說道,“你來負責,找一些能工巧匠,好好研究研究說明書,把這電話搞定”。管家找出了平時愛搗鼓的那些隊友,把說明書給了他們。
果然,片刻功夫,有個隊友表示大概明白了,可以嘗試一把。於是二師兄就給了他資料庫山村的“聯繫方式”,他接著一頓操作猛如虎,把大伙整的一愣一愣的。
還別說,竟然通了,按照說明書上講的,這就相當於建立了一條和資料庫山村的“連接”,然後還要把這個連接設置成“不可自動掛斷”,OK,搞定了。就把這個隊友稱為“接線員”吧。
接線員把電話交給了管家,管家心想這畢竟是Tomcat府上的東西,自己不能喧賓奪主,於是就把電話給了二師兄。二師兄道,“好,承蒙諸位看得起在下,那我就宣佈本次交流開始”。又把電話給了管家。
領導先講話這是自古以來的規矩,管家確認電話暢通後,就交給了自己的領導。於是老二Service通過老三Mapper,使用這個電話,終於和資料庫山村“村長”MySql通上話了,一番寒暄過後,終於可以一對一的交流了。
隊友1從管家處領取電話,坐到桌子前,打開本子,拿起電話,一面和對方溝通,一面記錄一些東西。一段時間以後,他和對方互相道謝,結束了交流。
隊友2從管家處領取電話,和對方進行了交流。接著隊友3從管家處領取電話,又進行了長時間的交流。管家一看,電話快沒電了,就把電話交給了自己的領導。
老二Service和村長MySql又是一番“互相吹捧”,最後約定改日再聊。然後就把電話又給了管家,管家確認沒有人再使用了,於是就掛斷了電話。
眼見天色已晚,二師兄安頓好大家,把電話拿去充電後,自己也去休息了。
意外收穫
第二天一大早,老二讓管家負責好今天的交流,自己就去找二師兄了。在管家的指導下,交流有條不紊的進行著。
半上午的時候,老二匆匆忙忙的回來了,拿出一個紙條,上面寫著資料庫山村的另一個電話號碼,讓管家幫他撥通這個號碼。
管家一看,隊友正在用電話交流著呢,但是領導的事情又不能違抗,讓隊友掛斷電話放棄交流也不太合適啊。突然腦中一道靈光閃過。
記得昨天研究說明書時,看到過呼叫保持這種技術,就是讓當前通話保持住,然後再開啟一個全新的通話,等新的通話結束後,原來保持住的通話可以恢復。
管家讓接線員進行處理,一番操作後成功了,只不過為啥是個女人的聲音,哦,管家意識到這可能是個“私人”電話,於是識趣的和大家一起“慢慢地”向門外走去。
看樣子自己的領導和那個女的很熟悉。這會是誰呢?管家一時也整不明白。一番腦細胞碰撞後,仿佛有了一點眉目,那應該是領導的一個筆友,平時都是書信來往。
管家總是去幫忙寄信和收信,既然是資料庫山村的人,那平時都應該交流的是SQL優化啥的相關話題吧。當然,這是猜的,因為私拆領導信件犯法。
好長時間之後,領導終於完事了,把電話交給了管家。管家掛斷了和這個女人的通話,並把之前保持住的那個通話進行了恢復,然後讓隊友繼續之前的學術交流。
領導心裡美滋滋的,我猜他一定在想什麼時候還有活動啊,也去買個無繩電話。這樣可以多和筆友進行“學術交流”了。
演員謝幕
異姓三兄弟都是我們的老朋友,再熟悉不過了。二師兄呢是一個線程,說明Spring事務的執行是和當前線程相關聯的。
老二Service的管家其實就是事務管理器,負責事務的整體工作。接線員可以認為是DataSource,負責和資料庫建立一條連接(Connection)。
把電話設置為不可自動掛斷,表示的是把資料庫連接設置為不自動提交事務,需要註意的是,這個設置是由事務管理器來操作的,而不是接線員。
開頭的領導講話,接下來的隊友1/2/3的學術交流,還有最後的領導吹捧,其實是4個標有@Transactional註解的方法。且在第1個方法里調用了其它3個方法。
他們用的都是同一通電話在交流,說明4個方法的執行用的是同一個和資料庫的連接,即一根繩子上的螞蚱。最後管家掛斷電話,表明是事務管理器提交了事務。
在第二天時,把當前通話進行呼叫保持,即對應於把當前線程上正在運行的事務掛起。撥通領導的私人電話,對應於當前線程新建一條到資料庫的連接,即一個全新的事務。
管家掛斷了領導的私人通話,即提交了這個新事務。然後恢復之前被保持的那個通話,即恢復之前那個被掛起的事務,使它重新成為當前線程正在運行的事務。
最後,領導沒有買無繩電話,而是直接買了智能手機,並下載了微信。哈哈,你懂的。
PS:本文只是巨集觀描述,實際的事務代碼執行比這要複雜一些。
(END)
作者是工作超過10年的碼農,現在任架構師。喜歡研究技術,崇尚簡單快樂。追求以通俗易懂的語言解說技術,希望所有的讀者都能看懂並記住。下麵是公眾號和知識星球的二維碼,歡迎關註!