节点启动时fatal error: concurrent map writes
【问题分类】
- bug
- P2P网络相关(包含libp2p,liquid)
- 链账户身份与权限相关(证书问题、public、多签投票问题)
- 核心交易引擎相关(交易池、DAG)
- 共识相关
- 智能合约相关
- 存储相关
- SDK相关
- 长安链CMC工具
- 长安链管理台
- 长安链浏览器
- 长安链合约IDE
- 长安链web签名插件
- 跨链相关
- 轻节点相关
- 隐私计算相关
- 密码学相关
- 环境依赖
- 其他补充:
【问题描述】(请对问题进行描述,方便定位问题)
不断改变配置并重启的过程中发现新的panic日志,表现形式为fatal error: concurrent map writes,用户启动节点时节点发生panic定位到是/root/chainmaker-go/module/blockchain/blockchain_start.go的121发生bug
121行bc.startModules[moduleNameConsensus] = struct{}{}的写入导致bug的发生
bc.startModules的定义在/root/chainmaker-go/module/blockchain/blockchain.go第97行,可以看出这是一个并发不安全的map
可以换成sync.Map使得并发安全
【相关日志文件】(如果有报错日志请贴图,或者上传附件)
chainmaker-go 的 log/system.log & bin/panic.log file *
SDK 的 sdk.log file
【系统信息】(请填写系统信息,方便定位问题)
- chainmaker-go version * : [v2.3.4]
- OS & version * : ubuntu-22.04.3-live-server-amd64, Linux version 5.15.0-119-generic
To upload designs, you'll need to enable LFS and have an admin enable hashed storage. More information