java - 單例服務(wù)解決多進(jìn)程寫文件
問題描述
現(xiàn)在需要一個(gè)多進(jìn)程寫文件的程序
如果直接寫則需要保證進(jìn)程對(duì)文件句柄加鎖
現(xiàn)在想通過spring 注冊(cè)一個(gè)單例的寫入服務(wù)
多個(gè)程序在寫入文件時(shí),去請(qǐng)求spring 的接口去寫入文件
這樣的方案是否可行?
或者用一個(gè)單例的RPC服務(wù)?
單例即能保證寫文件的時(shí)候是一個(gè)實(shí)例,避免多線程、多進(jìn)程同步問題!
問題解答
回答1:我認(rèn)為這樣還是不行的,本質(zhì)上Spring只是幫你管理實(shí)例,線程安全的問題還是要自己解決
再者,你說(shuō)的是多進(jìn)程寫文件,通過rpc也僅僅是多線程方式吧?
其實(shí)本質(zhì)就是想實(shí)現(xiàn)一個(gè)線程安全的文件寫接口,單例是OK的,自己的實(shí)例當(dāng)作鎖就行了
回答2:=_=! 一個(gè)多進(jìn)程的程序?
回答3:用zookeeper,zookepper一個(gè)特點(diǎn)是寫同一個(gè)znode只能有一個(gè)客戶端(進(jìn)程)寫入成功,就用這個(gè)客戶端寫文件,或者利用數(shù)據(jù)庫(kù)寫入同一個(gè)主鍵只有一個(gè)可以插入成功的特點(diǎn)
相關(guān)文章:
1. android - Genymotion 微信閃退 not find plugin.location_google.GoogleProxyUI2. docker綁定了nginx端口 外部訪問不到3. javascript - 想要用Ajax 即時(shí)返回XML 中的數(shù)據(jù),前后端怎么選擇?4. IOS app應(yīng)用軟件的id號(hào)怎么查詢?比如百度貼吧的app-id=4779278135. 前端工程師 - html5的CANVAS都可以用哪些格式的圖片資源?6. mac里的docker如何命令行開啟呢?7. 如何解決docker宿主機(jī)無(wú)法訪問容器中的服務(wù)?8. html5 - 水果機(jī)小游戲的實(shí)現(xiàn)思路是怎樣的?9. html5 - 如何禁用360極速瀏覽器的 瀏覽器內(nèi)核選擇10. angular.js - 在ionic下,利用javascript導(dǎo)入百度地圖,pc端可以顯示,移動(dòng)端無(wú)法顯示
