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