需求:
最近生產環境有個套殼掃描的小程式,20個作業站點,A類和B類站點各10個。
A站點做一些測驗資料上傳,上傳SN好之后B站點掃描。如果A沒有過站資訊,B站點掃描SN號不通過。
我的思路:
做了一個webservice,但是不想讓B站點一直去呼叫資料庫。
想著A站點過站后只管將SN寫入靜態類的Dictionary,同時寫入資料庫。B站點第一步先查詢webservice的靜態類中的dictionary,沒有查到的情況再進行資料庫查詢操作。
最大的擔心,寫入和查詢靜態類會不會產生鎖死的情況。
大家有沒有類似經驗,或者有更好的方案,交流一下。
uj5u.com熱心網友回復:
快取的真正概念,在于它應該自動“清理快取”,例如根據記憶體占用情況、使用次數、存活時間、依賴于其它快取的改變,等等條件而自動級聯洗掉。把一個靜態記憶體變數叫做“快取”這是個錯誤概念,靜態變數就是靜態變數原本的概念就好了,用不著在亂想亂起名字了。uj5u.com熱心網友回復:
多用戶、并發訪問有沒有bug,以及其它一切是是非非,以測驗為準。你應該自己寫上幾行測驗代碼來反復測驗幾千遍。只有你自己寫測驗才明白真實的業務邏輯,有bug就貼出能重現問題的源代碼和除錯截屏來,靠別人給你概念是寫不好程式的。uj5u.com熱心網友回復:
其實本質,就是先查詢快取,快取沒有,在去資料庫拉取最新。這個是常規的提高性能的做法。
邏輯上沒什么大問題。
資料庫往快取寫入資料時,需要鎖。
uj5u.com熱心網友回復:
1.微軟有執行緒安全字典ConcurrentDictionary,這是對你本身提問的回答2.問題iis會自己重啟應用程式池,所以這個字典會自己丟失,所以你完全依賴記憶體字典,業務上是否有保證?
3.微軟還有Cache類可以完成相同要求
4.假設不考慮iis應用池重啟問題。你打算把這個字典里的專案保留多長時間,你不可能永遠把他丟在記憶體里
所以綜合考慮,此處應該是用Cache,因為他會自動逐出過期專案,按你的專案描述,我可以理解為“卡口檢查”,這一般都會有正常業務周期,比如資料保存1天。1天外超時未處理檢查
個人選擇 CacheFactory,因為他同時支持記憶體快取,Redis快取,memcache快取,和多級快取
,
uj5u.com熱心網友回復:
以前都是寫的單站掃描啥的,像這種20個工位一起操作的沒寫過,我看網上有的是用nosql來做快取uj5u.com熱心網友回復:
一個簡單(但是也基本就是全部框架)的并發測驗是類似這樣的var rnd = new Random();
var tasks = Enumerable.Range(0, 100).Select(i => Task.Run(async () =>
{
Console.WriteLine($"測驗{i}開始了");
await Task.Delay(rnd.Next(1000));
Console.WriteLine($"測驗{i}結束了");
}));
await Task.WhenAll(tasks);
Console.WriteLine($"測驗完成");
當然這里只是個例子,它創建100個并發任務,然后執行它們。你應該自己寫上幾行代碼,呼叫自己的業務的千差萬別的 BLL 代碼,一旦程式有改動、或者一有空就自己測驗系統是否靠譜。
uj5u.com熱心網友回復:
“從外界操作界面來看”而產生的說法,主要都是你做事情搞設計的太少,而不敢去想造成的。但是其實那方面沒有啥技術,你老板隨便找一個外行、找個小姑娘都能瞎指揮程式員。那種問題不應該反復糾結,而應該認為是自己的本職作業。那么關鍵執行力就是你能不能把程式的關鍵bug盡早讓它跳出來,并且保證部署之后不出什么意外。這種軟體工程程序,才是你應該去擔心和解決的問題。
uj5u.com熱心網友回復:
謝謝大家。小廠IT,就自己一個人,寫點程式滿足小需求。找不到方向的時候很迷茫回帖的都是俺朋友
uj5u.com熱心網友回復:
其實你的問題并不是no不nosql。
你的問題其實是。B類公用A類的物件。也就是分布式共享狀態
站在分布式共享狀態的情況考慮,我們現在可能的選型
1.全域快取redis
2.全域狀態同步zookekeep/etcd/consol
3.樓上sp喜歡推薦的Orlen這類基于actor模式的分布式異步處理。(Actor模式本身就采用全域狀態統一管理方式開發)
uj5u.com熱心網友回復:
WebService是一種跨編程語言和跨作業系統平臺的遠程呼叫技術。只有通過Web Service,客戶端和服務器才能夠自由的用HTTP進行通信
而HTTP是無狀態協議,靜態物件并不能獨立于應用之外
所以你的問題并無討論的基礎
uj5u.com熱心網友回復:
以前做的專案,有些物件不能序列化,我就是放靜態變數里的,用的挺爽。只要使用得當,沒什么不可以。uj5u.com熱心網友回復:
上了上了,用redis做了快取,晚點貼用測驗跑一下,看看效果。現階段2工位上的員工表示有很大提升
uj5u.com熱心網友回復:
注意并發,沒有什么問題,static在所有請求中間共享。并且要注意行程回收的問題。轉載請註明出處,本文鏈接:https://www.uj5u.com/net/17962.html
標籤:C#
