夢中驚醒
在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年的碼農,現在任架構師。喜歡研究技術,崇尚簡單快樂。追求以通俗易懂的語言解說技術,希望所有的讀者都能看懂並記住。下面是公眾號和知識星球的二維碼,歡迎關注!