grin中
挖矿的文档
https://github.com/mimblewimble/grin/blob/master/doc/stratum.md
结构体
data:image/s3,"s3://crabby-images/2b44f/2b44f545bd83b8e902aab9b954e40129c58b4e6f" alt=""
data:image/s3,"s3://crabby-images/2668b/2668b976ad17c4cad98862f7300958226310f4f8" alt=""
data:image/s3,"s3://crabby-images/0f979/0f97961f9df6330eb90199d7b9be50dc971bc1dc" alt=""
矿工获取挖矿数据
data:image/s3,"s3://crabby-images/2d963/2d963775b1cebce4e3050f6ea19027a2849482a9" alt=""
JobTemplate中的pre_pow,这时候还没有经过hash。只是经过to_hex()
data:image/s3,"s3://crabby-images/2464b/2464b137f0e512319ba47e9d4ace8034da216ed0" alt=""
to_hex()
data:image/s3,"s3://crabby-images/22ecf/22ecf28edbd36e438c351431b136ac47b38e949e" alt=""
grin-miner中
在client.rs中
这里面有挖矿时跟节点交互的各种方法。重点关注send_message_get_job_tempalte
,这个就是向服务器发送了getjobtemplate
的jsonrpc请求。
data:image/s3,"s3://crabby-images/a3b91/a3b91ff49f7f20e37c735a0e3cd5ea5ab7c468df" alt=""
继续看
Controller
的run
方法,方法太长,只挑选部分代码
// 向服务器发送请求
let _ = self.send_message_get_job_template();
// 从服务器读取数据
match self.read_message() {
}
// 对消息进行判断
debug!(LOGGER, "Received message: {}", m);
// Deserialize to see what type of object it is
let v: serde_json::Value = serde_json::from_str(&m).unwrap();
// Is this a response or request?
if v["id"] == String::from("Stratum") {
// this is a request
let request: types::RpcRequest =
serde_json::from_str(&m).unwrap();
let _ = self.handle_request(request);
continue;
} else {
// this is a response
let response: types::RpcResponse =
serde_json::from_str(&m).unwrap();
let _ = self.handle_response(response);
continue;
}
// run的任务未完,后面继续。。。
如果这是一个response
,就处理他let _ = self.handle_response(response);
handle_response
中会对收到的消息类型进行判断,然后进行相应的处理。
data:image/s3,"s3://crabby-images/dec87/dec87c863d0ceff85388219ee4ee049b6d56c0ca" alt=""
重要的是这句
let _ = self.send_miner_job(job);
,就是发送给挖矿那边了。
挖矿那边处理接受之后的信息
data:image/s3,"s3://crabby-images/36a1c/36a1ce1e9c5c90e0de16b11da796b6837ffb6ec8" alt=""
我们看他对信息简单加工之后,又调用了
run_solver
data:image/s3,"s3://crabby-images/4f147/4f147895a64be5de28b6108fb4dd308d3867cf0d" alt=""
再找到
data:image/s3,"s3://crabby-images/e5b94/e5b949d784d9118ab23b3c55b37dd5363c6028b9" alt=""
这里的run_solver就是c的代码了
data:image/s3,"s3://crabby-images/d654d/d654dec5508f2778b67e6c420c6e45f9140fbfe8" alt=""
data:image/s3,"s3://crabby-images/15c32/15c32575ce10a62f0de69fadc1547df3bd83c5ea" alt=""
按照之前在文档中的说明,
run_solver
中传进去的header
需要先进行hash,然后用hash生成图,然后才是cuckoo cycle
算法发挥了。data:image/s3,"s3://crabby-images/4ac2b/4ac2b59b00d2d34e8ce1393644a5c6e68ce936e6" alt=""
data:image/s3,"s3://crabby-images/18def/18deff7dab43450345d22434ee23e43c0001941f" alt=""
data:image/s3,"s3://crabby-images/e7dec/e7decd76dad38b8c8e7262898e0641b11b774f9a" alt=""
data:image/s3,"s3://crabby-images/e421f/e421f11e8603385ba9397bf098fe9abee774023e" alt=""
首先将nonce添加到header最后,然后进行blake2b
运算。keys->setkeys(hcrkey)
就是生成图的keys了,还不是图。
再看挖矿那边的代码
再main.rs中
data:image/s3,"s3://crabby-images/826b9/826b9b46cf8ae0aa20ca9bdc8eb6c8ee4e5f3bea" alt=""
solution
pub struct Proof {
/// Power of 2 used for the size of the cuckoo graph
pub edge_bits: u8,
/// The nonces
pub nonces: Vec<u64>,
}
再看找到解决方案后的hash
data:image/s3,"s3://crabby-images/f59d4/f59d45b4b3eaf3376921e293594ed28ef8b33d7e" alt=""
网友评论