欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

java多線(xiàn)程在項(xiàng)目中的應(yīng)用

多線(xiàn)程對(duì)于編程人員都不陌生,比如我們常用的數(shù)據(jù)庫(kù)連接池、tomcat等。本博客主要說(shuō)一下我在工作中對(duì)多線(xiàn)程的使用的思考。具體多線(xiàn)程的使用方法就不在這里向大家介紹了。

創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的市中網(wǎng)站建設(shè)公司,市中接單;提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行市中網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

1.背景

我最近做的項(xiàng)目是供應(yīng)鏈相關(guān)的項(xiàng)目,而對(duì)于項(xiàng)目中涉及的各種單據(jù)都需要傳給另外一套系統(tǒng)做賬(財(cái)務(wù)系統(tǒng)),比如:合同單據(jù)、采購(gòu)單據(jù)、收貨單據(jù)等,每類(lèi)單據(jù)都會(huì)有工作流。

1) 最初

流程是這樣的 首先在系統(tǒng)創(chuàng)建單據(jù),提交之后開(kāi)始走審批流及各種通知,當(dāng)審批流審批結(jié)束之后,觸發(fā)同步財(cái)務(wù)系統(tǒng)。當(dāng)我們系統(tǒng)有單據(jù)發(fā)生變化時(shí),如果單據(jù)已經(jīng)審批通過(guò),會(huì)將變化的內(nèi)容推送給財(cái)務(wù)系統(tǒng)。

那這會(huì)有什么問(wèn)題呢?假如我們現(xiàn)在在做一個(gè)發(fā)票沖銷(xiāo)的功能,當(dāng)用戶(hù)在頁(yè)面點(diǎn)擊它之后,首先在我們系統(tǒng)完成沖銷(xiāo)邏輯,然后調(diào)用財(cái)務(wù)系統(tǒng)將單據(jù)同步給它。

起初我們是采用同步的方式調(diào)用財(cái)務(wù)系統(tǒng)的接口,調(diào)用財(cái)務(wù)系統(tǒng)的接口我們方法又需要等待它返回給我們操作狀態(tài)(成功還是失敗),而對(duì)于有修改的業(yè)務(wù)方法我們都會(huì)在方法上使用事務(wù),這會(huì)導(dǎo)致我們方法占用事務(wù)時(shí)間過(guò)長(zhǎng)產(chǎn)生數(shù)據(jù)庫(kù)行級(jí)鎖沖突問(wèn)題。

2) 思考

當(dāng)項(xiàng)目上線(xiàn)之后,經(jīng)常收到用戶(hù)反饋說(shuō)項(xiàng)目出錯(cuò),查看日志發(fā)現(xiàn)經(jīng)常出現(xiàn)行級(jí)鎖問(wèn)題。為什么會(huì)產(chǎn)生行級(jí)鎖問(wèn)題呢?
比如采購(gòu)單來(lái)說(shuō),采購(gòu)單采用的是頭行結(jié)構(gòu)(主單和明細(xì)),采購(gòu)單包含采購(gòu)的數(shù)量,收貨數(shù)量,在途數(shù)量等字段,而在收貨時(shí),也會(huì)操作收貨單對(duì)應(yīng)的采購(gòu)單,如果在采購(gòu)單和收貨單同時(shí)操作同一采購(gòu)單號(hào)的單據(jù),并且操作字段都需要同步到財(cái)務(wù)系統(tǒng),就會(huì)導(dǎo)致方法占用事務(wù)過(guò)長(zhǎng),更容易產(chǎn)生行級(jí)鎖問(wèn)題。

2.解決方案

除了會(huì)產(chǎn)生上面所說(shuō)的行級(jí)鎖問(wèn)題之外,其實(shí)還有另外一個(gè)問(wèn)題,就是分布式事務(wù)來(lái)保證數(shù)據(jù)一致性問(wèn)題。

1) 異步方式

采用多線(xiàn)程的方式,將我們系統(tǒng)中所有需要同步的到財(cái)務(wù)系統(tǒng)的地方都改成異步的方式,因?yàn)橄到y(tǒng)有很多種類(lèi)型的單據(jù),比如說(shuō)我們系統(tǒng)有6種單據(jù),那我們就創(chuàng)建一個(gè)大小為6的線(xiàn)程池,每個(gè)線(xiàn)程池配一個(gè)阻塞隊(duì)列。每個(gè)線(xiàn)程池和6種單據(jù)一一對(duì)應(yīng),這樣就可以保證我們不會(huì)開(kāi)啟太多線(xiàn)程而占用系統(tǒng)資源。
java多線(xiàn)程在項(xiàng)目中的應(yīng)用
例如采購(gòu)單修改之后,除了做在本系統(tǒng)中的保存之外,同步到財(cái)務(wù)系統(tǒng)的地方只需要將采購(gòu)單的同步請(qǐng)求放入線(xiàn)程池中。
除了異步的方式之外,我們還可以同步的方式發(fā)送給對(duì)方系統(tǒng)之后,對(duì)方系統(tǒng)立即返回,當(dāng)對(duì)方系統(tǒng)執(zhí)行完畢之后,回調(diào)我們系統(tǒng)的接口,我們系統(tǒng)再做成功之后的邏輯處理。

2) MQ的方式

除了上面這種方式之外,就是還可以采用MQ的方式,將需要同步的單據(jù)發(fā)送到MQ里面,對(duì)方系統(tǒng)從MQ里面取單據(jù),取出的不同單據(jù)做不同的業(yè)務(wù)區(qū)分。

當(dāng)前題目:java多線(xiàn)程在項(xiàng)目中的應(yīng)用
瀏覽地址:http://chinadenli.net/article12/jggigc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊(cè)自適應(yīng)網(wǎng)站靜態(tài)網(wǎng)站做網(wǎng)站關(guān)鍵詞優(yōu)化標(biāo)簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司