lotus miner 元数据 删除 重建

2024-05-26 02:48
文章标签 数据 删除 重建 lotus miner

本文主要是介绍lotus miner 元数据 删除 重建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

lotus miner 元数据重建

  • 主网 lotus-miner backup
  • 测试网模拟lotus-miner元数据损坏,重建
  • 指定原来的矿工号重新初始化
  • 环境变量配置miner API
  • 运行 lotus-worker
  • 修改LevelDB
  • 扇区ID 从27开始
  • 修改nextid 大的数字
  • 参考

主网 lotus-miner backup

Backup and restore

测试网模拟lotus-miner元数据损坏,重建

# echo $LOTUS_MINER_PATH
/raid0/calibnet/miner

删除miner目录下所有内容

# rm -rf /raid0/calibnet/miner/*

指定原来的矿工号重新初始化

lotus-miner init --no-local-storage --actor=t矿工号 --owner=t3钱包 --sector-size=32GiB
  • 运行miner
nohup lotus-miner run >> /var/log/calibnet/miner.log 2>&1 &
lotus-miner info
  • 修改lotus-miner配置文件config.tomlstorage.json
lotus-miner stop
# cat $LOTUS_MINER_PATH/config.toml | grep -Ev '^$|#'
[API]ListenAddress = "/ip4/192.168.1.92/tcp/2345/http"RemoteListenAddress = "192.168.1.92:2345"
[Backup]
[Libp2p]
[Pubsub]
[Subsystems]
[Dealmaking][Dealmaking.RetrievalPricing][Dealmaking.RetrievalPricing.Default][Dealmaking.RetrievalPricing.External]
[Sealing]BatchPreCommits = falseAggregateCommits = false
[Storage]AllowAddPiece = falseAllowPreCommit1 = falseAllowPreCommit2 = falseAllowCommit = falseAllowUnseal = false
[Fees][Fees.MaxPreCommitBatchGasFee][Fees.MaxCommitBatchGasFee]
[Addresses]
[DAGStore]
  • 存储目录重新init会报错
# lotus-miner storage attach --init --store /store/
ERROR: path is already initialized
  • 存储目录可以直接修改
# cat $LOTUS_MINER_PATH/storage.json
{"StoragePaths": null
}
# cat $LOTUS_MINER_PATH/storage.json
{"StoragePaths": [{"Path": "/store"}]
}
lotus-miner storage list

看不到扇区列表

lotus-miner sectors list

环境变量配置miner API

lotus-miner auth api-info --perm admin

运行 lotus-worker

nohup lotus-worker run >> /var/log/calibnet/worker.log 2>&1 &

修改LevelDB

  • pledge 扇区编号ID会从0开始,需要修改nextid
  • 查看扇区的最新ID,最新扇区ID为26
lotus-miner proving deadlines
lotus-miner proving deadline <Index>
lotus-miner proving check <Index>
# mkdir leveldb_nextid
# cd leveldb_nextid/
# go mod init leveldb_nextid
# vim leveldb_nextid.go
  • 停止mienr
lotus-miner stop

cat leveldb_nextid.go

package main
import ("fmt""log""github.com/syndtr/goleveldb/leveldb""encoding/binary"
)func main(){// 打开数据库db, err := leveldb.OpenFile("/raid0/calibnet/miner/datastore/metadata", nil)if err != nil {  log.Fatal(err)  }  // 关闭数据库defer db.Close()// 遍历数据fmt.Println("遍历数据")iter := db.NewIterator(nil, nil)  for iter.Next() {  fmt.Printf("key:%s, value:%s\n", iter.Key(), iter.Value())  //fmt.Printf("key:%s \n", iter.Key())  }  iter.Release()  buf := make([]byte, binary.MaxVarintLen64)size := binary.PutUvarint(buf, 26)fmt.Print(size)fmt.Printf("%v \n", buf[:size])db.Put([]byte("/storage/nextid"), buf[:size], nil) nextid, _ := db.Get([]byte("/storage/nextid"), nil)  fmt.Printf("读取单条数据 nextid:  %v\n", nextid)}
go get github.com/syndtr/goleveldb/leveldb
# go run leveldb_nextid.go 
遍历数据
key:/backupds/log/head, value:1647508356.log.cbor;5364dd4d-2ff9-4302-82a5-cb513421b5ca;1647509713
key:/datatransfer/provider/transfers/versions/current, value:2
key:/deals/provider/storage-ask/1/latest, value:�cAsk�ePriceE�emVerifiedPriceE���lMinPieceSizelMaxPieceSizMinerD�iTimestamp�fExpiryeSeqNoiSignatureXa�΍|o��T�k}ֿ�)����SW�����(\�E &��+���!4/J�;�"
�ܳ%��y�g����K!��5���m��IFh��6��.
key:/deals/provider/storage-ask/versions/current, value:1
key:/deals/provider/versions/current, value:1
key:/miner-address, value:�
key:/retrievals/provider/retrieval-ask/1/latest, value:�lPricePerByte@kUnsealPrice@oPaymentIntervalwPaymentIntervalIncrease
key:/retrievals/provider/retrieval-ask/versions/current, value:1
key:/retrievals/provider/versions/current, value:1
key:/storagemarket/cid-infos/versions/current, value:1
key:/storagemarket/pieces/versions/current, value:1
1[26] 
读取单条数据 nextid:  [26]

扇区ID 从27开始

# lotus-miner sectors pledge
Created CC sector:  27
# lotus-miner sectors list
ID  State    OnChain  Active  Expiration  Deals
27  Packing  NO       NO      n/a         CC

修改nextid 大的数字

  • nextid 修改为1600
         buf := make([]byte, binary.MaxVarintLen64)size := binary.PutUvarint(buf, 1600)fmt.Print(size)fmt.Printf("%v \n", buf[:size])db.Put([]byte("/storage/nextid"), buf[:size], nil) 
读取单条数据 nextid:  [192 12]
# lotus-miner sectors pledge
Created CC sector:  1601

参考

  1. /storage/nextid
  2. leveldb 修改
  3. 原语云
  4. goleveldb
  5. Go语言中调用levelDB

这篇关于lotus miner 元数据 删除 重建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1003335

相关文章

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

使用MyBatis TypeHandler实现数据加密与解密的具体方案

《使用MyBatisTypeHandler实现数据加密与解密的具体方案》在我们日常的开发工作中,经常会遇到一些敏感数据需要存储,比如用户的手机号、身份证号、银行卡号等,为了保障数据安全,我们通常会对... 目录1. 核心概念:什么是 TypeHandler?2. 实战场景3. 代码实现步骤步骤 1:定义 E

使用C#导出Excel数据并保存多种格式的完整示例

《使用C#导出Excel数据并保存多种格式的完整示例》在现代企业信息化管理中,Excel已经成为最常用的数据存储和分析工具,从员工信息表、销售数据报表到财务分析表,几乎所有部门都离不开Excel,本文... 目录引言1. 安装 Spire.XLS2. 创建工作簿和填充数据3. 保存为不同格式4. 效果展示5