Chia绘图P盘机器配置:
i9-10850K,10C / 20T,最大持续提升时钟= 4.7 Ghz
64 GB DDR4 3600 RAM,CL18
2x2TB Samsung 980 Pro RAID0 @ PCIe 3.0 x 4(绘图驱动器)
1x1TB WD SN750 @ PCIe 3.0 x 4(分段驱动器)
Ubuntu Server 20.04 LTS
我正在并行运行13个作业。完成大约需要8个小时,因此平均每天大约需要4 TiB。
在进一步介绍之前,我一定要指出,对于任何认真的绘图员来说,真正的瓶颈是单核CPU性能,而不是存储性能。寻求更好的存储是没有意义的,因为任何能够保持1500MB / s的读写吞吐量就足够了。如果对您来说还不够好,请购置其中两个并运行RAID0。
进步绘图速度的第一个要害是应用LINUX。不要糟蹋您昂贵的硬件在Windows中运行绘图,这10%的性能丧失将很难收回,即使您做的一切正确,您的绘图速度仍然比我们的Linux用户慢10%。
如果您买得起2TB的驱动器,并且碰巧有两个空的M.2 NVMe插槽,则分辨购置2个1TB的存储棒,并将其作为RAID0运行。AMD和Intel都支撑主板人造RAID,或者您也可以在mduxm的LINUX中实现该功效,mdadm是许多人所信任的壮大的软RAID。
获得暂存/缓冲驱动器。它不必定要很大,它可以是您所处的SATA SSD或某些NVMe SSD不能做的绘图驱动器。我为此应用WD SN750。一旦完成,我的地块便可以转储到该驱动器中,并且我的CPU可以在不到1分钟的时间内启动新的地块。CPU时间非常可贵,您不盼望CPU空转是因为绘图仪正在以125MB / s的传输速率将绘图卸载到HDD上。考虑一下,传输大小为101 GiB的地块将消费几乎16分钟的时间!为啥要糟蹋这16分钟?即使是SATA SSD,也可以极大地缩短收拾和传输之间的停机时间。
天色已晚,我们将在明天讨论SMT或超线程。
更正了我说的错别字,我实际上并行绘制了14个,而不是实际绘制的13个。
让我们进一步谈谈这个话题。我要讨论的是SMT /超线程。
随着CPU时钟速度的进步,瓶颈本质上将来自许多其他设备,并且当这种情况产生时,CPU将被迫等候下一组指令。启用S??MT后,可以将一个物理核心“拆分”为两个逻辑核心,以减少空闲时间并进步效率,但是两个逻辑核心不等于两个物理核心,这更像是将处理能力进步了30%(乐观地) 。
关于可以并行运行的最大作业数量的快速而邋遢的数学运算是将CPU的物理核心数量增长30%。在上面的示例中,i9 10850K是一个10核CPU,将其增长30%,我得到13,这是我可以作为单线程并行运行的最大作业数。
“您可以”并不意味着“您应当”。还有许多其他因素在起作用。你有足够的内存吗?并行应用13个作业会在高峰应用时吞噬40 GB以上的内存。你有足够的临时空间吗?您的分段驱动器可以跟上吗?等等,最好是分析您自己的吞吐量,尤其是在最后一个阶段,在该阶段结束绘图过程,并将绘图文件传输到目标地位。
最后,每个人都想知道我的打印设置和我的交错排列。完整复制我的设置是不可取的,因为每个人的机器运行都略有不同。我应用Plotman来管理我的交错排列,而Chia绘图参数为r = 6,b = 3600。其他所有内容均为默认设置。
那里有很多工作管理工具,所以我认为我在这里所做的工作可以模仿Plotman之外的其他人。让我们深入懂得Plotman设置。
在Plotman中,一项简洁的功效是您可以把持进入阶段1、2、3、4(称为“重要”)和7个子阶段(称为“次要”)的过程。由于阶段2:7是存储和RAM应用量的绝对最大值,因此很直观地阐明应如何安排其工作。
——稍后会再详细阐明交错和作业安排—–
好的,让我们谈谈交错和调度。这有点复杂,因为我想在阶段1以外的阶段中应用所有13个“核心”,因此需要应用一些技巧。
首先,转到Plotman设置并将最大作业限制设置为13。此类设置共有3种,tmp_dir限制= 13,全局限制= 2(目前)和交错限制= 2。
然后,将重要限制设置为2,将次要限制设置为1(这将限制处于第一阶段的作业)。从r = 6开端,并行履行2个作业,现在您已经用完了13个“核心”中的12个。
下一步很重要,需要密切监督-当您看到先前安排的2个作业进入阶段2时,将Plotman中的全局限制更改为4,以在r = 6中启动另外2个作业,现在您有了2 + 12应用的核心数量超过了我们拥有的核心数量,这是13个,但这是不可避免的。
再次编辑该配置,为其余9个作业设置r = 4,然后一次将全局限制扩大2(现在应当是6),最终达到13,所以当下一阶段开端时,您将得到2 * 4 + 4 =应用12个内核。
这实际上是在预先应用更多的内核,然后在阶段2释放这些内核时,便为CPU供给了更多的绘图作业以充分利用它。最后,您应当在第2阶段及以后的阶段中拥有13个作业,或者在第1阶段中应用4个或更少的内核拥有1个作业,而在第2-4阶段中的其他工作仅应用1个内核。
第一阶段大约需要 大约需要10-12ks,而全部过程需要27-30ks,因此可以在完成一项工作的同时启动两项工作。在三个生成周期之后,您将达到全局极限,其中第一阶段可能有两个作业,而第二阶段2-4中则有11个作业。
这是我的IO和CPU应用率的屏幕截图。
usr = CPU读/写=临时磁盘IO
编辑:修复了一些语法毛病和更好的格式。
编辑:同一个Chia农场主 / u / FJDNMAN 指出,我对Plotman的设置有曲解,现已更正。
$ sudo crontab -e
* * * * * [ $(ls -al #staging_dir | grep plot | wc -l) -gt 0 ] && [ $(ps aux | grep mv | grep -v grep | wc -l) -eq 0 ] && mv #staging_dir_plots #final_dir
将#staging_dir和#final_dir调换为您自己的路径,例如/ mnt / staging和/ mnt / dest
将#staging_dir_plots调换为#staging_dir / *。plot,例如/mnt/staging/*.plot
可读格式:
[检查是不是有绘图文件] && [检查mv命令是不是未运行] && [移动文件]
## Powershell file buffering script
## needs administrator privileges
## v0.5
while ($true)
{
$check_interval = 30 # in seconds
$bfr_folder = 'C:' # SSD buffer folder
$farm_folder = 'D:' # Destination/Farming folder
$chia_running = ((get-process -Name chia).path | findstr "unpacked").count
$current_time = (Get-Date -f "HH:mm")
$current_date_time = (Get-Date -f "MM-dd-HH:mm:ss")
$count = (Get-ChildItem -Path $bfr_folder -Force | Where-Object {$_.Extension -eq ".plot"}).count
if ($count -gt 0)
{
Write-Host $current_time $count "new plots found. Beginning Transfer"
robocopy $bfr_folder $farm_folder /MOV *.plot ## change your directories accordingly. FROM -> TO
}
else
{
Write-Host $current_date_time":" "There are" $chia_running "Chia plotters running."
Write-Host $current_date_time":" $count "plot files found."
[int]$Time = $check_interval
$Length = $Time / 100
For ($Time; $Time -gt 0; $Time--) {
$min = [int](([string]($Time/60)).split('.')[0])
$text = " " + $min + " minutes " + ($Time % 60) + " seconds left"
Write-Progress -Activity "No new files... Watiting for..." -Status $Text -PercentComplete ($Time / $Length)
Start-Sleep 1 ## countdown timer for checking folder activity, default = plot interval, line 31
}
}
}
用法:打开一个文本编辑器,将其另存为您爱好的名称。ps1,以管理员权限打开Windows PowerShell,然后运行脚本。不要忘记将策略设置为容许脚本运行。
最新solo项目:1天1P云端方案,性价比高。云主机挖Chia币解决方案,p盘解决方案,一站式农场收割解决方案,详询在线QQ客服。TikTok千粉号购买平台:https://tiktokusername.com/
TOP