简介
Atlas 是一条采用POS共识算法的链,其工作原理如下:
每个 validator 投票选出每个 epoch 的验证区块的 validator
每个 epoch 结束时,根据选举的得票数获得奖励。
前提条件
硬件要求:
机器配置 MAP 是一种权益证明网络,其硬件要求与工作量证明网络不同。权益证明共识的 CPU 密集程度较低, 但对网络连接和延迟更敏感。以下是在 MAP 网络上运行验证器的标准要求列表: •内存:16GB RAM •CPU:四核2.5 GHz(64位) •磁盘:256 GB SSD 存储,另外还需要一个辅助 HDD •网络:至少100 Mb 输入/输出以太网,具有光纤互联网连接、理想的冗余连接和 HA 交换机
地图数量 您的帐户需要至少有 1,000,000 MAPO
软件要求
构建atlas需要git、Go(1.14或更高版本)和C编译器。您可以使用您最喜欢的包管理器来安装它们。
如何成为新的 validator
为了让您的资产更安全,我们需要您设置一些必要的身份识别参数才能成为 validator 。我们也设置了相应的阈值,以便筛选那些真正想为链做出贡献的人。 当然,我们会给这些人相应的奖励。 以下步骤视为您的第一次操作,因为您只需执行一次以下操作即可成为 validator 。除非您注销验证器或取消 相应的操作,否则您无需执行第二次操作,以免浪费您的 gas 费。
第1步:创建账号
在这一步中,您需要将您的身份信息存储到相应的管理合约中,该合约将管理您的账户、密钥和元数据。 此步骤的目的是通过授权用于签名证明、投票、验证替代密钥来确保锁定的 MAPO 更加安全。通过 这样做,您可以在保持访问存储您锁定的 MAPO 的密钥的同时继续参与协议。 您需要 createAccount 命令来执行上述操作,更多关于 createAccount 命令的详细信息请参阅这里。
第2步:授杈
授权一个地址代表账号签名共识消息。这个授权地址称为 signer(签名人)。正如他的名字一样,他只负责签名,你的奖 励不会发放给 signer,而是发放给上一步创建的账户,
第3步:锁定 MAP
我们设置成为 validator 的阈值是锁定 1,000,000 MAPO 到相应的管理智能合约中。 这部分锁定的 MAPO 将用于以后的惩罚,这也是当选的条件之一。 您需要 LockedMAP 命令来执行上述操作,更多关于 LockedMAP 命令的详细信息请参这里。
第4步: validator 注册
此步骤是注册成为新 validator 的关键步骤。 您需要 register 命令来执行上述操作,更多关于register 命令的详细信息请参阅这里。 到这一步,您将成功注册为 validator 。接下来,您可以尝试为自己投票。如何投票请参阅这里。
第5步:投票
validator 必须至少拥有总票数的 0.001 比例才能考虑参加选举。所以 validator 不能没有选票。 我们可以使用我们的 validator 账户为自己投票,也可以让其他 validator 或投票者为自己投票。 我们在第了步中锁定了 1,000,000 MAP,现在为自己投票是一个明智的决定
示例
启动你的节点
在启动节点之前你需要先构建 atlas,如何构建图集请参阅这里
你需要准备两个 keystore,一个用于质押的称为 account,一个用于参与共识签名区块的 signer。
如果希望 atlas 节点在后台运行而不挂起,可以使用nohup和&的组合,或者 screen 之类的工具。下面我们将使用 screen 进行演示
account.json
:account 的 keystore 文件 signer.json
:signer 的 keystore 文件
--miner.validator
:指定 signer 的地址 --port 30321
:确保端口在防火墙上打开
./atlas --datadir ./node --syncmode "full" --port 30321 --v5disc --mine --miner.validator 0x98efa292822eb7b3045c491e8ae4e82b3b1ac005 --unlock 0x98efa292822eb7b3045c491e8ae4e82b3b1ac005
INFO [08-01|16:15:45.369] Bumping default cache on mainnet provided=1024 updated=4096
INFO [08-01|16:15:45.370] Maximum peer count ETH=50 LES=0 total=50
INFO [08-01|16:15:45.371] Set global gas cap cap=50,000,000
INFO [08-01|16:15:45.371] Allocated trie memory caches clean=614.00MiB dirty=1024.00MiB
INFO [08-01|16:15:45.371] Allocated cache and file handles database=/Users/t/data/atlas-1/atlas/chaindata cache=2.00GiB handles=5120
INFO [08-01|16:15:45.722] Opened ancient database database=/Users/t/data/atlas-1/atlas/chaindata/ancient readonly=false
......
> net
{
listening: true,
peerCount: 6,
version: "22776",
getListening: function(callback),
getPeerCount: function(callback),
getVersion: function(callback)
}
......
INFO [08-01|16:40:40.796] Finalized func=Finalize block=1 epochSize=50000 duration="333.422µs" lastInEpoch=false
INFO [08-01|16:40:40.797] Imported new chain segment blocks=1 txs=0 mgas=0.000 elapsed=5.391ms mgasps=0.000 number=1 hash=62d029..14f4c1 age=1mo4d23h dirty=7.07KiB
INFO [08-01|16:40:51.790] Finalized func=Finalize block=2 epochSize=50000 duration="106.969µs" lastInEpoch=false
INFO [08-01|16:40:51.790] Imported new chain segment blocks=1 txs=0 mgas=0.000 elapsed=4.913ms mgasps=0.000 number=2 hash=c2b741..35869d age=1mo4d23h dirty=10.79KiB
INFO [08-01|16:40:53.892] Finalized func=Finalize block=3 epochSize=50000 duration="104.285µs" lastInEpoch=false
INFO [08-01|16:40:53.893] Finalized func=Finalize block=4 epochSize=50000 duration="105.568µs" lastInEpoch=false
节点启动后会通过内置的引导节点连接到网络,并同步区块数据。
创建账号
./marker createAccount --rpcaddr https://rpc.maplabs.io --keystore ./account.json --name "validator"
INFO [07-08|14:54:28.097] Create account func=createAccount address=0x73bC690093b9dD0400c91886184A60cC127b2c33 name=validator
INFO [07-08|14:54:28.097] === create Account ===
INFO [07-08|14:54:28.102] TxInfo func=sendContractTransaction TX data nonce =0 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|14:54:28.103] Please waiting func=getResult txHash =0xa8d9dfb5b74720a940e904972784225d605ebb111fe92b87184ccb3a54ffd452
INFO [07-08|14:54:30.726] Transaction Success func=queryTx block Number=9
INFO [07-08|14:54:30.726] === setName name ===
INFO [07-08|14:54:30.731] TxInfo func=sendContractTransaction TX data nonce =1 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|14:54:30.732] Please waiting func=getResult txHash =0xf26f4f8b4a7f6ab44a70fe474162fe22b1bcd7694b4c1a42ed0b1a70d062d5ee
INFO [07-08|14:54:35.779] Transaction Success func=queryTx block Number=10
INFO [07-08|14:54:35.779] === setAccountDataEncryptionKey ===
INFO [07-08|14:54:35.784] TxInfo func=sendContractTransaction TX data nonce =2 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|14:54:35.785] Please waiting func=getResult txHash =0x430533536a6305b603c9abd6282a4fec359c7f42b8dbd78cf4d3f340ec9bf31b
INFO [07-08|14:54:40.224] Transaction Success func=queryTx block Number=11
授权
signer 账号:0x98efa292822eb7b3045c491e8ae4e82b3b1ac005 signer 私钥:8df920b696ef3f5fdcf01624405ea8236b2b4907766ad61d42ce877df05f8bca
./marker authorizeValidatorSigner --rpcaddr https://rpc.maplabs.io --keystore ./account.json --signerPriv 8df920b696ef3f5fdcf01624405ea8236b2b4907766ad61d42ce877df05f8bca
INFO [07-08|14:55:00.015] === makeECDSASignatureFromSigner ===
INFO [07-08|14:55:00.015] === signer === account=0x98EFA292822eB7b3045C491e8ae4E82B3b1AC005
INFO [07-08|14:55:00.015] ECDSASignature result=0x712c3f5deaf6d5012ff94dc6a8c3f5bd3d5570ba1f878343fd48767f88fb317d76d39ca33e274eb245d617252d7a44cf048d8579cd896440183f5fbe9f65ca8800
INFO [07-08|14:55:00.015] authorizeValidatorSigner func=authorizeValidatorSigner address=0x73bC690093b9dD0400c91886184A60cC127b2c33
INFO [07-08|14:55:00.015] === authorizeValidatorSigner ===
INFO [07-08|14:55:00.032] TxInfo func=sendContractTransaction TX data nonce =4 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|14:55:00.032] Please waiting func=getResult txHash =0xb73a1376e661d523e44b87c37e2e03cc36534d3a550808245f263aaad358b0ad
INFO [07-08|14:55:05.078] Transaction Success func=queryTx block Number=16
锁定 MAPO
./marker lockedMAP --rpcaddr https://rpc.maplabs.io --keystore ./account.json --lockedNum 1000000
INFO [07-08|14:54:49.141] === Lock gold ===
INFO [07-08|14:54:49.141] Lock gold amount=1000000000000000000000000
INFO [07-08|14:54:49.148] TxInfo func=sendContractTransaction TX data nonce =3 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|14:54:49.150] Please waiting func=getResult txHash =0x698140b0ad8677706a4d10d3c5c72f15a8e143623be84a6ed514990fe3f5e5f3
INFO [07-08|14:54:50.765] Transaction Success func=queryTx block Number=13
注册 validator
./marker register --rpcaddr https://rpc.maplabs.io --keystore ./account.json --signerPriv 8df920b696ef3f5fdcf01624405ea8236b2b4907766ad61d42ce877df05f8bca --commission 150000
INFO [07-08|15:09:53.230] === Register validator ===
INFO [07-08|15:09:53.230] === commission === commission=150,000
INFO [07-08|15:09:53.233] === getTotalVotesForValidator === admin=0x73bC690093b9dD0400c91886184A60cC127b2c33
INFO [07-08|15:09:53.234] === getTotalVotesForValidator === result=0
INFO [07-08|15:09:53.237] === makeBLSProofOfPossessionFromsigner ===
INFO [07-08|15:09:53.420] TxInfo func=sendContractTransaction TX data nonce =7 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|15:09:53.421] Please waiting func=getResult txHash =0xfb0487e7196df7489e90ab91217251da5fc7d07b2bc2d2f4ea67966a506a4cd6
INFO [07-08|15:09:55.241] Transaction Success func=queryTx block Number=194
验证注册
至此我们已经完成了 validator 的注册步骤,现在我们来验证一下是否成为了 validator。
./marker getTotalVotesForEligibleValidators --rpcaddr https://rpc.maplabs.io
INFO [07-08|15:10:03.301] Validator: addr=0xeA9efaA232A4567EaC21C8C096f8BfF84595A244 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:10:03.301] Validator: addr=0x6ACdC02223100189d82A958d888F54fA27d60e8A vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:10:03.301] Validator: addr=0xA53516D49A72019692Ac69cB42641942597654f6 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:10:03.301] Validator: addr=0x5d643Dfb9ae372ce4Fdbc80890156E2CD8290846 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:10:03.301] Validator: addr=0x73bC690093b9dD0400c91886184A60cC127b2c33 vote amount=0
投票
投票数不能大于锁定票数。
有关投票和选举的更多信息,请点击以下链接查看: 投票 选举
现在我们来给 validator 投票,投票的命令如下:
./marker vote --rpcaddr https://rpc.maplabs.io --keystore ./account.json --target 0x73bc690093b9dd0400c91886184a60cc127b2c33 --voteNum 1000000
INFO [07-08|15:11:13.693] === vote Validator === admin=0x73bc690093b9dd0400c91886184a60cc127b2c33 voteTargetValidator=0x73bC690093b9dD0400c91886184A60cC127b2c33 vote MAP Num=1000000
INFO [07-08|15:11:13.709] TxInfo func=sendContractTransaction TX data nonce =4 gasLimit =4,500,000 gasPrice =101,000,000,000 chainID =1,098,789
INFO [07-08|15:11:13.710] Please waiting func=getResult txHash =0x8ec67797871ea313f7beea33900db8f680ddf2d01f35894c65e1212151729747
INFO [07-08|15:11:15.123] Transaction Success func=queryTx block Number=210
验证投票
现在,让我们验证投票是否有效。
./marker getTotalVotesForEligibleValidators --rpcaddr https://rpc.maplabs.io
INFO [07-08|15:21:45.881] Validator: addr=0xeA9efaA232A4567EaC21C8C096f8BfF84595A244 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:21:45.881] Validator: addr=0x6ACdC02223100189d82A958d888F54fA27d60e8A vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:21:45.881] Validator: addr=0xA53516D49A72019692Ac69cB42641942597654f6 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:21:45.881] Validator: addr=0x5d643Dfb9ae372ce4Fdbc80890156E2CD8290846 vote amount=1,000,000,000,000,000,000,000,000
INFO [07-08|15:21:45.881] Validator: addr=0x73bC690093b9dD0400c91886184A60cC127b2c33 vote amount=1,000,000,000,000,000,000,000,000
从结果来看,我已经成功给自己投票了,但是还不够。我们需要在下一个 epoch 中 调用 RPC 来最终确定我们是否被选为可以参与区块生成的验证者,如下所示:
curl -X POST -H "Content-Type: application/json" -d '{"jsonrpc":"2.0","method":"istanbul_getValidators","params":[],"id":1}' https://rpc.maplabs.io
# Output
{
"jsonrpc": "2.0",
"id": 1,
"result": [
"0x5d643dfb9ae372ce4fdbc80890156e2cd8290846",
"0xa53516d49a72019692ac69cb42641942597654f6",
"0x6acdc02223100189d82a958d888f54fa27d60e8a",
"0xea9efaa232a4567eac21c8c096f8bff84595a244",
"0x98efa292822eb7b3045c491e8ae4e82b3b1ac005" # our signer
]
}
Last updated