记sentinel里防止多并发下读取脏数据的操作
生活随笔
收集整理的這篇文章主要介紹了
记sentinel里防止多并发下读取脏数据的操作
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
閱讀sentinel的contextutil.java文件里的代碼時,發現了一個在高并發場景下防止讀取臟數據的操作,代碼截取如下:
private static volatile Map<String, DefaultNode> contextNameNodeMap = new HashMap<>();Map<String, DefaultNode> newMap = new HashMap<>(contextNameNodeMap.size() + 1);newMap.putAll(contextNameNodeMap);newMap.put(name, node);contextNameNodeMap = newMap;可以發現contextNameNodeMap是一個加了volatile關鍵字的,輕量級的線程之間可以互相看見的共享操作,下面四行代碼其實就是一行代碼contextNameNodeMap.put即可,但是為什么要這樣做呢?是為了防止迭代穩定性問題,如果在改的時候有多個線程去進行讀操作,那么就容易造成臟數據的讀取,所以進行一次拷貝操作再重新賦值是一個很完美的解決辦法。
總結
以上是生活随笔為你收集整理的记sentinel里防止多并发下读取脏数据的操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java中动态顺序死锁问题
- 下一篇: k8s常用命令汇总