修改日期 | 修改人 | 备注 |
2021-08-17 23:26:39[当前版本] | 文艺范儿 | 格式调整 |
2021-08-17 23:25:09 | 文艺范儿 | 格式调整 |
2021-08-17 23:24:46 | 文艺范儿 | 格式调整 |
2021-08-17 23:23:30 | 文艺范儿 | 格式调整 |
仅当您完全满足要在其中进行挖掘的网络的最低硬件要求时,才能进行挖掘。 由于采矿过程在多个方面对机器要求很高,并且依赖于精确的配置,因此强烈建议您着手使用Linux系统的管理经验。
在尝试遵循本指南之前:
首次启动时加快证明参数的下载
运行Lotus需要下载链的证明参数,这些参数是大文件,默认情况下托管在中国境外,在中国下载非常慢。 为了解决这个问题,用户在运行Lotus,Lotus-miner和Lotus-worker时,应设置以下环境变量:
export IPFS_GATEWAY=https://proof-parameters.s3.cn-south-1.jdcloud-oss.com/ipfs/
在构建过程中加快Go模块的下载
构建Lotus需要下载一些Go模块。这些通常托管在Github上,而Github来自中国的带宽非常低。要解决此问题,请在运行Lotus之前通过设置以下变量来使用本地代理:
export GOPROXY=https://goproxy.cn
参考这里:
https://golang.google.cn/doc/install
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
apt-get install opencl-headers wget https://pkg-config.freedesktop.org/releases/pkg-config-0.29.2.tar.gz && tar -zxvf pkg-config-0.29.2.tar.gz && cd pkg-config-0.29.2/ && ./configure && make && make check && sudo make install ##必要时,再安装: apt-get install ocl-icd-libopencl1 apt-get install libhwloc-dev sudo ln -s /usr/lib/x86_64-linux-gnu/libOpenCL.so.1 /usr/lib/libOpenCL.so
git clone https://github.com/filecoin-project/lotus.git cd lotus/ # 加入主网 make clean all # 或者加入测试网,或者开发网: make clean calibnet # Calibration 最小 32GiB 扇区 make clean nerpanet # Nerpa 最小 512MiB 扇区 # 最后执行安装步骤 sudo make install
建议在您的环境中设置以下环境变量,以便在每次启动任何Lotus应用程序时(即启动守护程序时)进行定义。
# See https://github.com/filecoin-project/bellman export BELLMAN_CPU_UTILIZATION=0.875
BELLMAN_CPU_UTILIZATION是一个可选变量,用于指定多乘幂计算的一部分,以将其移至与GPU并行的CPU中。 这是为了使所有硬件都处于占用状态。 间隔必须为0到1之间的数字。0.875值是一个很好的起点,但是如果需要最佳设置,则应该进一步调整一下。 不同的硬件设置最佳值。 忽略此环境变量也可能是最佳选择。
# See https://github.com/filecoin-project/rust-fil-proofs/ export FIL_PROOFS_MAXIMIZE_CACHING=1 # 以内存换取速度。(1x sector-size of RAM - 32 GB). export FIL_PROOFS_USE_GPU_COLUMN_BUILDER=1 # precommit2 GPU 加速 export FIL_PROOFS_USE_GPU_TREE_BUILDER=1 # 以下内容提高了 PreCommit1 的速度,代价是使用完整的 CPU 多核而不是单个内核。应该与 CPU 关联设置一起使用! export FIL_PROOFS_USE_MULTICORE_SDR=1
如果您在不同的机器节点上运行Lotus挖矿,请按如下进行设置:
export FULLNODE_API_INFO=<api_token>:/ip4/<lotus_daemon_ip>/tcp/<lotus_daemon_port>/http
并确保ListenAddress已启用远程访问。有关如何获取令牌的说明。
同样,Lotus-miner(作为Lotus Miner守护程序的客户端应用程序)可以通过设置,与远程Miner进行通信:
export MINER_API_INFO="TOKEN:/ip4/<IP>/tcp/<PORT>/http"
如果只有128GiB的RAM,则需要确保系统至少提供额外的256GiB的非常快速的交换(最好是NVMe SSD),否则将无法封装扇区:
sudo fallocate -l 256G /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile # 显示当前交换空间并记下当前最高优先级 swapon --show # 将以下行附加到 /etc/fstab(确保最高优先级),然后重新启动 # /swapfile swap swap pri=50 0 0 sudo reboot # 检查 256GB 交换文件是否自动挂载并具有最高优先级 swapon --show
您至少需要一个BLS钱包(用于主网的f3 …)才能进行挖掘。我们建议尽管使所有者和矿工地址分开使用。因此,至少创建两个钱包(除非您已经有一些钱包):
# A new BLS address to use as owner address: lotus wallet new bls t3... # A new BLS address to use as worker address: lotus wallet new bls t3...
接下来,确保将一些资金发送到矿工机的地址,以便完成矿工设置。
有关矿工可以使用的不同钱包以及如何配置它们的更多信息,请阅读矿工地址指南。
提示:安全地备份你的钱包
$ lotus wallet list Address Balance Nonce Default t3wr3eebezggxg5ho4lnxxrmt36kum4dshlhf4usn7wwjoyiopfqyr5jogjxjx7uxl3ie4a 0 FIL 0 X
从矿工机开始,它需要读取和验证FileCoin的证明参数。 这些可以预先下载(推荐),或者校正过程。 验证参数由多个文件组成,在32GiB扇区的情况下,总共超过100GiB。
我们建议设置一个客户本地存储参数,保证一级缓存能够在第一次运行的时候被创建:
export FIL_PROOFS_PARAMETER_CACHE=/path/to/folder/in/fast/disk export FIL_PROOFS_PARENT_CACHE=/path/to/folder/in/fast/disk2
每次重启的时候,都会开始读取参数,因此使用具有非常快速的访问的磁盘,如NVME驱动器,将加快矿工机器的启动速度。 当未设置上述变量时,默认情况下,机器在默认情况下,会停止运行到 / var / tmp /,这通常缺少足够的空间。
要下载参数,请执行以下操作:
# Use sectors supported by the Filecoin network that the miner will join and use. # lotus-miner fetch-params <sector-size> lotus-miner fetch-params 32GiB lotus-miner fetch-params 64GiB
您可以在网络仪表板中验证网络的扇区大小。 FIL_PROOFS _ * _ CACHE变量不仅应在下载时保持定义,而且在启动Lotus Miner(或工作程序)时也应保持定义。
总结以上所有内容,请确保:
矿工地址有一些资金,以便可以初始化矿工。
定义了以下环境变量,这些变量可用于任何Lotus Miner运行:
export LOTUS_MINER_PATH=/path/to/miner/config/storage export LOTUS_PATH=/path/to/lotus/node/folder # 当你使用了本地节点时需要进行设置. export BELLMAN_CPU_UTILIZATION=0.875 # 这个值的设置取决于你的硬件 export FIL_PROOFS_MAXIMIZE_CACHING=1 export FIL_PROOFS_USE_GPU_COLUMN_BUILDER=1 # 有GPU时,设为1 export FIL_PROOFS_USE_GPU_TREE_BUILDER=1 # 有GPU时,设为1 export FIL_PROOFS_PARAMETER_CACHE=/fast/disk/folder # 高速缓存,大于 100GiB! export FIL_PROOFS_PARENT_CACHE=/fast/disk/folder2 # 缓存,大于 50GiB! export TMPDIR=/fast/disk/folder3 # 密封时使用
参数已预取到上面指定的缓存文件夹中
系统具有足够的交换区(swap),并且处于活动状态
$ lotus --help NAME: lotus - Filecoin decentralized storage network client # Filecoin去中心化存储网络客户端 USAGE: lotus [global options] command [command options] [arguments...] VERSION: 1.11.1-dev+git.a577bf3 COMMANDS: daemon Start a lotus daemon process # 启动一个 Lotus 守护进程 backup Create node metadata backup # 创建节点元数据备份 version Print version # 打印版本号 help, h Shows a list of commands or help for one command # 显示命令列表或一个命令的帮助 BASIC: send Send funds between accounts # 在帐户之间发送资金 wallet Manage wallet # 管理钱包 client Make deals, store data, retrieve data # 进行交易、存储数据、检索数据 msig Interact with a multisig wallet # 与多重签名钱包互动 filplus Interact with the verified registry actor used by Filplus paych Manage payment channels # 管理支付渠道 DEVELOPER: auth Manage RPC permissions # 管理 RPC 权限 mpool Manage message pool # 管理消息池 state Interact with and query filecoin chain state # 与 Filecoin 链状态交互和查询 chain Interact with filecoin blockchain # 与 Filecoin 区块链交互 log Manage logging # 管理日志 wait-api Wait for lotus api to come online # 等待lotus api上线 fetch-params Fetch proving parameters # 获取证明参数 NETWORK: net Manage P2P Network # 管理p2p网络 sync Inspect or interact with the chain syncer # 检查或与链同步器交互 STATUS: status Check node status # 检查节点状态 GLOBAL OPTIONS: --interactive setting to false will disable interactive functionality of commands (default: true) --force-send if true, will ignore pre-send checks (default: false) --help, -h show help (default: false) --version, -v print the version (default: false)
NAME: lotus-miner - Filecoin decentralized storage network miner USAGE: lotus-miner [global options] command [command options] [arguments...] VERSION: 1.11.1-dev+git.a577bf3 COMMANDS: init Initialize a lotus miner repo # 初始化一个 Lotus 矿工 repo run Start a lotus miner process # 启动一个 Lotus 矿工进程 stop Stop a running lotus miner # 停止正在运行的 lotus 矿工程序 config Output default configuration # 打印默认的配置信息 backup Create node metadata backup # 创建节点元数据备份 version Print version # 打印版本号 help, h Shows a list of commands or help for one command CHAIN: actor manipulate the miner actor # 矿工操作 info Print miner info # 打印矿工信息 DEVELOPER: auth Manage RPC permissions # 管理 RPC 权限 log Manage logging # 管理日志 wait-api Wait for lotus api to come online fetch-params Fetch proving parameters # 获取证明参数 MARKET: storage-deals Manage storage deals and related configuration # 管理存储交易和相关配置 retrieval-deals Manage retrieval deals and related configuration # 管理检索交易和相关配置 data-transfers Manage data transfers # 管理数据传输 NETWORK: net Manage P2P Network # 管理p2p网络 RETRIEVAL: pieces interact with the piecestore STORAGE: sectors interact with sector store # 与扇区存储交互 proving View proving information # 查看证明信息 storage manage sector storage # 管理扇区存储 sealing interact with sealing pipeline # 与密封管道互动 GLOBAL OPTIONS: --actor value, -a value specify other actor to check state for (read only) # 指定其他参与者检查状态 --color (default: false) --miner-repo value, --storagerepo value Specify miner repo path. flag(storagerepo) and env(LOTUS_STORAGE_PATH) are DEPRECATION, will REMOVE SOON (default: "~/.lotusminer") [$LOTUS_MINER_PATH, $LOTUS_STORAGE_PATH] --help, -h show help (default: false) --version, -v print the version (default: false)
在首次运行矿机之前,请先执行以下操作:
lotus-miner init --owner=<address> --worker=<address> --no-local-storage
在启动矿工之前,对其进行配置非常重要,以便可以从Filecoin网络中的任何对等方访问它。为此,您将需要一个稳定的公共IP,并按如下所示编辑~/.lotusminer/ / config.toml:
... [Libp2p] ListenAddresses = ["/ip4/0.0.0.0/tcp/24001"] # choose a fixed port AnnounceAddresses = ["/ip4/<YOUR_PUBLIC_IP_ADDRESS>/tcp/24001"] # important! ...
一旦启动矿工,请确保可以连接到其公共IP /端口。
现在您可以启动Lotus挖矿机了:
lotus-miner run
或者,如果您使用的是systemd服务文件:
systemctl start lotus-miner
警告:在确认矿工不仅正在运行而且在其公共IP地址上可以访问之前,才能从前面步骤继续进行操作
一旦矿工机启动并运行,就在链上发布您的矿工机地址(您在上面配置的),以便其他节点可以直接与之对话并进行交易:
lotus-miner actor set-addrs /ip4/<YOUR_PUBLIC_IP_ADDRESS>/tcp/24001
现在,您的矿工应该已经初步设置并正在运行,但是还有一些建议的任务可以在黄金时间准备好:
设置您的自定义存储布局(如果使用--no-local-storage,则为必需)。
编辑矿工配置设置以符合您的要求
了解什么是关闭/重启矿机的正确时机
使用矿工封装某个扇区的时间来更新ExpectedSealDuration:通过运行基准测试或确认一个扇区并记下时间来发现它。
配置其他密封工作机,以提高矿工密封部门的能力。
为WindowPost消息配置一个单独的地址