Changing config item `disable_block_file_db` to `true` leads to panic: runtime error: index out of range [7] with length 1
【问题分类】
- bug
- P2P网络相关(包含libp2p,liquid)
- 链账户身份与权限相关(证书问题、public、多签投票问题)
- 核心交易引擎相关(交易池、DAG)
- 共识相关
- 智能合约相关
- 存储相关
- SDK相关
- 长安链CMC工具
- 长安链管理台
- 长安链浏览器
- 长安链合约IDE
- 长安链web签名插件
- 跨链相关
- 轻节点相关
- 隐私计算相关
- 密码学相关
- 环境依赖
- 其他补充:
【问题描述】(请对问题进行描述,方便定位问题)
更改 disable_block_file_db
为true导致节点panic,显示panic: runtime error: index out of range [7] with length 1
而且配置的上方显示这个配置项的值是default: true
的,但是实际上默认是false的。
分析触发原因是/root/go/pkg/mod/chainmaker.org/chainmaker/store/v2@v2.3.6/blockdb/blockkvdb/blockkvdb.go:522进行了binary.BigEndian.Uint64(vBytes)的调用,但是这时候vBytes是一个长度为1,具体内容为[0]的切片
最后导致在/usr/local/go/src/encoding/binary/binary.go:179时访问b[7]导致panic
【相关日志文件】(如果有报错日志请贴图,或者上传附件)
【系统信息】(请填写系统信息,方便定位问题)
- 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