GPU挖掘
硬件
算法是内存难解的,为了使DAG适合内存,每个GPU需要1-2GB内存,如果你得到错误提示:Error GPU mining. GPU memory fragmentation? 说明你没有足够的内存。GPU挖矿软件是基于OpenCL实现的,AMD GPU会比同一水准的NVIDIA GPU更快。ASIC和FPGA相对低效因而被阻拦。要给芯片集成平台获取openCL,尝试:
- AMD SDK openCL
- NVIDIA CUDA openCL
Ubuntu Linux设置
对于这个快速指南,你会需要 Ubuntu 14.04 以上的版本以及 fglrx 图像驱动器。你也可以使用 NVidia 驱动器和其他平台,但是你必须要找到自己的方式来获得有效的 OpenCL 安装,比如 Genoil 的 ethminer 分叉。
如果你在用15.04,到“软件与更新〉额外的驱动器”设置为“从 fglrx 为 AMD图形加速器使用视频驱动器”。
如果你在用14.04,到“软件与更新〉额外的驱动器”设置为“从fglrx为AMD图形加速器使用视频驱动器”。很遗憾,对于一些人来说,这种方法可能不管用,因为Ubuntu 14.04.02中有个已知的程序错误会阻止你转换到GPU挖矿所必须的专属图形驱动器。
所以,如果你遇到这个程序错误,先到“软件与更新〉更新”选择“预发行的可靠更新提议”。然后,回到“软件与更新〉额外的驱动器”设置为“从fglrx为AMD图形加速器使用视频驱动器”。重启之后,值得检查一下现在确实正确安装了驱动器(例如通过再到“额外驱动器”)。
不管做什么,如果你在用14.04.02,一旦安装之后,就不要改变驱动器或者驱动器配置。例如,aticonfig –initial的使用(尤其是-f, –force选项)会“破坏”你的设置。如果你偶然改变了配置,会需要卸载驱动器,重启,再次安装驱动器并重启。
Mac设置
wget http://developer.download.nvidia.com/compute/cuda/7_0/Prod/local_installers/cuda_7.0.29_mac.pkgsudo installer -pkg ~/Desktop/cuda_7.0.29_mac.pkg -target /brew updatebrew tap ethereum/ethereumbrew reinstall cpp-ethereum --with-gpu-mining --devel --headless --build-from-source
查看冷却状态:
aticonfig --adapter=0 --od-gettemperature
Windows设置
下载最新的 Eth++ 安装,在安装界面的“选择组件”页面选择ethminer。用 geth 使用 ethminer
geth account new // Set-up ethereum account if you do not have onegeth --rpc --rpccorsdomain localhost 2>> geth.log ðminer -G // -G for GPU, -M for benchmarktail -f geth.log
ethminer 在端口 8545(geth 的默认 RPC 端口)和 geth 沟通。你可以通过给 geth—rpcport 选项来改变这种情况。ethminer 会在任何端口发现geth。注意你需要用—rpccorsdomain localhos设置CORS标题。你也可以用-F http://127.0.0.1:3301 在ethminer设置端口。如果你想要在同一个电脑上挖几个实例,设置端口是必需的,尽管有些没有意义。如果你在私有链上测试,我们推荐你用CPU挖掘代替。
注意:你不需要把—mine选项给geth,或者在控制台开启挖矿,除非你想要在GPU挖掘顶端做CPU挖掘。
如果ethminer的默认无效,试试用—opencl-device X来规定OpenCL装置,其中X是{0, 1, 2,…}。用-M(基础测试程序)运行ethminer时,你会看到这样的文字:
Benchmarking on platform: { "platform": "NVIDIA CUDA", "device": "GeForce GTX 750 Ti", "version": "OpenCL 1.1 CUDA" }Benchmarking on platform: { "platform": "Apple", "device": "Intel(R) Xeon(R) CPU E5-1620 v2 @ 3.7
为geth排错:
geth --rpccorsdomain "localhost" --verbosity 6 2>> geth.log
为矿工排错:
make -DCMAKE_BUILD_TYPE=Debug -DETHASHCL=1 -DGUI=0gdb --args ethminer -G -M
注意:GPU挖矿时,散列率信息在 geth 上不可用。
用 ethminer 检查散列率,miner.hashrate 总会报告0。
用 eth 使用 ethminer
在单独的 GPU 上挖矿
为了在单独的GPU上挖矿,只需要用以下参数运行eth:
eth -v 1 -a 0xcadb3223d4eebcaa7b40ec5722967ced01cfc8f2 --client-name "OPTIONALNAMEHERE" -x 50 -m
- -v 1 将冗长的信息设置为1。不要被信息刷屏。
- -a YOURWALLETADDRESS 设置挖矿奖励会去的coinbase。以上地址只是一个例子。这一参数十分重要,确保不要在钱包地址出错,否则会接收不到以太币支出。
- --lient-name “OPTIONAL” 设置可选择的客户端名称,在网络上确定身份。
- -x 50 请求大量的端点。帮助在开始找到端点。
- -m on 在挖矿开启的状态下实际启动。
- -G 打开GPU挖掘。
客户端运行时,你可以用 geth 附属或 [ethconsole] 和它互动(https://github.com/ethereum/ethereum-console)。
在多个GPU上挖矿
用多个 GPU 和 eth 挖矿与用 geth 和多个 GPU 挖矿十分相似。确保 eth 节点和正确设置的 coinbase 地址一起运行:
eth -v 1 -a 0xcadb3223d4eebcaa7b40ec5722967ced01cfc8f2 —client-name “OPTIONALNAMEHERE” -x 50 -j
注意我们也添加了-j参数以使客户端有可用的 JSON-RPC 服务器与ethminer 实例沟通。此外由于 ethminer 可以为我们挖矿,我们移除了与挖矿相关的参数。每个GPU都会执行一个不同的 ethminer 实例:
ethminer --no-precompute -G --opencl-device X
X是索引号码,与你想 ethminer 用 {0, 1, 2,…} 的 OpenCL 装置一致。为了轻松获取 OpenCL 装置列表,你可以执行 ethminer —list-devices
,它会提供一个 OpenCL 可以检测到的所有装置,以及每个装置的一些附加信息。
下面是一个样本输出:
12345
[0] GeForce GTX 770CL_DEVICE_TYPE: GPUCL_DEVICE_GLOBAL_MEM_SIZE: 4286345216CL_DEVICE_MAX_MEM_ALLOC_SIZE: 1071586304CL_DEVICE_MAX_WORK_GROUP_SIZE: 1024
最 --no-precompute
参数请求 ethiminers 不要提前创建下一个 epoch 的DAG。尽管不推荐这样,因为每次 epoch 过渡的时候,你都会有一个挖矿中断。
基准测试程序
挖矿能力通常以内存带宽衡量。我们的实现写在 OpenCL上,很典型地在NVidia 上被 AMD GPU 支持得更好。实验证据确认了在价格方面,AMD GPU 比对应的 NVidia 挖矿表现更好。
用基准程序测试单一装置设置,你可以在基准测试程序模式下通过 -M 使用 ethminer。
ethminer -G -M
如果你有很多装置,你会喜欢分别用基准程序测试,可以用 --opencl-device
选项,与之前章节相似: ethminer -G -M --opencl-device X
用
ethminer--list-devices
来列出可能的数字替代 X {0, 1, 2,…}。 开始在
Windows 上挖矿
首先要下载 geth windows binary。
解压缩 Geth (单击右键选择打开),启用命令提示符。用 cd 导航到 Geth 数据文件夹的位置(例如 cd / 到 C: 盘)
输入geth--rpc
启动 geth。
进入以后,以太坊区块链会开始下载。有时候防火墙肯能会阻止同步进程(阻止时会有提示)。如果被阻止,点击“允许进入”。
下载安装 ethminer, C++ 挖矿软件 (防火墙或Windows本身可能会有反应,允许进入)
打开另一个命令提示符 (保持第一个运行!)输入 cd/Program\ Files/Ethereum(++)/release
改变目录。
确保 eth 完成区块链同步。如果同步不再进行,就可以在命令提示符输入ethminer -G
开启挖矿进程。
此时可能会出现一些问题。如果有错误发生, 可以输入 Ctrl+C
来中断矿工。如果错误显示(提示)“内存不足”,就说明没有足够的 GPU
内存来挖以太币。
矿池挖矿
矿池挖矿是旨在通过联合参与矿工的挖矿力来解决预期收益问题的合作社(挖矿的矿工的算力来解决预期收益问题的合作组织)。作为回报,通常收取0-5%的挖矿奖励。挖矿池从中央账户用工作量证明提交区块并按照参与人贡献的挖矿力比例来重新分配奖励。
警告:大多数挖矿池包含第三方,中心组件,意味着他们是不需信任的。换言之,挖矿池操作人可以把你的收入拿走。谨慎操作。有很多具备开源数据库、不需信任的、去中心化的挖矿池。
警告:挖矿池只会外包工作量证明运算,他们不会使区块生效或运行虚拟机来检查执行交易带来的状态过渡。 这能有效地使挖矿池在安全方面像单个节点一样表现,他们的增长会造成51%攻击的中心化威胁。确保遵守网络能力分配,不要让挖矿池长得太大。
矿池
coinotron
nanopool
ethpool — 可预测的单独挖矿,非常规支出机制,附属于etherchain.org。
supernova
coinmine.pl
eth.pp.ua
talkether — 非常规支出机制,部分去中心化
weipool
ethereumpool
pooleum
alphapool
cryptopool
unitedminers
dwarfpool — 尽量避免(目前超过网络的50%)
laintimes — 停止使用
挖矿相关资源汇总
过去 24 小时以太币链上领先的矿工
2015年8月挖矿池散表率分配
论坛上未维护的挖矿池列表
cryptocompare上的挖矿盈利能力计算器
cryptowizzard上的挖矿盈利能力计算器
etherscan上的挖矿盈利能力计算器
In The Ether上的挖矿盈利能力计算器
etherscan上的挖矿难度表
POS vs POW
https://www.reddit.com/r/ethereum/comments/38db1z/eli5_the_difference_between_pos_and_pow/
https://blog.ethereum.org/2014/11/25/proof-stake-learned-love-weak-subjectivity/
https://www.reddit.com/r/ethereum/comments/42o8oy/can_someone_explain_the_switch_to_pos_how_and_when/
参考资料:
文章中的列表对应的链接可以参考《Ethereum Homestead Documentation》第67页1.6.4 GPU mining