mirror of
https://gitee.com/BDWare/cm
synced 2025-01-10 09:54:03 +00:00
merge pbft algorithm
This commit is contained in:
parent
6bf6343c50
commit
b136681526
@ -384,9 +384,6 @@ public class ContractClient {
|
|||||||
get.asyncGet("", "setIdentifier", alias, null);
|
get.asyncGet("", "setIdentifier", alias, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isUnit() {
|
|
||||||
return contractMeta.contract.getType() != ContractExecType.Sole;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String signResult(String result) {
|
public String signResult(String result) {
|
||||||
return contractMeta.contract.signResult(result);
|
return contractMeta.contract.signResult(result);
|
||||||
|
@ -890,6 +890,7 @@ public class ContractManager {
|
|||||||
case RequestAllResponseHalf:
|
case RequestAllResponseHalf:
|
||||||
case Sharding:
|
case Sharding:
|
||||||
case Sole:
|
case Sole:
|
||||||
|
case PBFT:
|
||||||
ret = client.startProcess(ps);
|
ret = client.startProcess(ps);
|
||||||
conflictCheck = checkConflict(c, client, ret);
|
conflictCheck = checkConflict(c, client, ret);
|
||||||
if (null != conflictCheck) {
|
if (null != conflictCheck) {
|
||||||
@ -925,7 +926,7 @@ public class ContractManager {
|
|||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
default:
|
default:
|
||||||
return "todo";
|
return "contract manager can't support:" + c.getType();
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
@ -1462,10 +1463,11 @@ public class ContractManager {
|
|||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
ResultCallback eventExtractor = new ResultCallback() {
|
ResultCallback eventExtractor = new ResultCallback() {
|
||||||
@Override
|
@Override
|
||||||
public void onResult(String ret){
|
public void onResult(String ret) {
|
||||||
JsonObject result = JsonUtil.parseStringAsJsonObject(ret);
|
JsonObject result = JsonUtil.parseStringAsJsonObject(ret);
|
||||||
this.onResult(result);
|
this.onResult(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResult(JsonObject result) {
|
public void onResult(JsonObject result) {
|
||||||
ContractManager.instance.extractEventsFromContractResult(
|
ContractManager.instance.extractEventsFromContractResult(
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package org.bdware.sc.sequencing;
|
package org.bdware.sc.sequencing;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.bdware.sc.ContractManager;
|
import org.bdware.sc.ContractManager;
|
||||||
import org.bdware.sc.bean.ContractRequest;
|
import org.bdware.sc.bean.ContractRequest;
|
||||||
import org.bdware.sc.conn.Node;
|
import org.bdware.sc.conn.Node;
|
||||||
@ -12,6 +14,8 @@ import java.util.concurrent.TimeUnit;
|
|||||||
import java.util.concurrent.atomic.AtomicLong;
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
public class PBFTAlgorithm implements CommitAlgorithm {
|
public class PBFTAlgorithm implements CommitAlgorithm {
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger(PBFTAlgorithm.class);
|
||||||
|
|
||||||
static byte[] GETPUBKEY = "GETPUBKEY".getBytes();
|
static byte[] GETPUBKEY = "GETPUBKEY".getBytes();
|
||||||
Committer committer;
|
Committer committer;
|
||||||
Map<Node, PBFTMember> members;
|
Map<Node, PBFTMember> members;
|
||||||
@ -22,6 +26,7 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
Map<Integer, Pair<Node, PBFTMessage>> original;
|
Map<Integer, Pair<Node, PBFTMessage>> original;
|
||||||
boolean isMaster;
|
boolean isMaster;
|
||||||
private TrustfulExecutorConnection connection;
|
private TrustfulExecutorConnection connection;
|
||||||
|
private int sendID;
|
||||||
|
|
||||||
public PBFTAlgorithm(boolean isMaster) {
|
public PBFTAlgorithm(boolean isMaster) {
|
||||||
commitedMsg = new ArrayList<>();
|
commitedMsg = new ArrayList<>();
|
||||||
@ -31,6 +36,14 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
this.isMaster = isMaster;
|
this.isMaster = isMaster;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setSendID(int id) {
|
||||||
|
sendID = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addMember(Node node, PBFTMember member) {
|
||||||
|
members.put(node, member);
|
||||||
|
}
|
||||||
|
|
||||||
public void setCommitter(Committer c) {
|
public void setCommitter(Committer c) {
|
||||||
committer = c;
|
committer = c;
|
||||||
}
|
}
|
||||||
@ -46,13 +59,14 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
// pbftMessage.content.length);
|
// pbftMessage.content.length);
|
||||||
PCInfo temp;
|
PCInfo temp;
|
||||||
PBFTMessage prepareMsg;
|
PBFTMessage prepareMsg;
|
||||||
System.out.println("[PBFTAlgorithm] recv: " + pbftMessage.getDisplayStr());
|
LOGGER.info("recv: " + pbftMessage.getDisplayStr());
|
||||||
switch (pbftMessage.type) {
|
switch (pbftMessage.type) {
|
||||||
case AddMember:
|
case AddMember:
|
||||||
PBFTMember member = PBFTMember.parse(pbftMessage.content);
|
// PBFTMember member = PBFTMember.parse(pbftMessage.content);
|
||||||
if (member != null)
|
// if (member != null)
|
||||||
members.put(sender, member);
|
// members.put(sender, member);
|
||||||
// case DeleteMember:
|
// case DeleteMember:
|
||||||
|
// JUST ignore
|
||||||
break;
|
break;
|
||||||
case Request:
|
case Request:
|
||||||
// all nodes save full content, clientIP, clientPort !!!!
|
// all nodes save full content, clientIP, clientPort !!!!
|
||||||
@ -91,12 +105,12 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
break;
|
break;
|
||||||
case Prepare:
|
case Prepare:
|
||||||
temp = info.get(pbftMessage.order);
|
temp = info.get(pbftMessage.order);
|
||||||
// System.out.println(getPort() + ": receive Prepare from:" + packet.getPort());
|
LOGGER.info("receive Prepare from:" + pbftMessage.sendID + " -> " + pbftMessage.order);
|
||||||
if (temp == null) {
|
if (temp == null) {
|
||||||
PCInfo pcInfo = new PCInfo();
|
PCInfo pcInfo = new PCInfo();
|
||||||
pcInfo.buff.add(pbftMessage);
|
pcInfo.buff.add(pbftMessage);
|
||||||
info.put(pbftMessage.order, pcInfo);
|
info.put(pbftMessage.order, pcInfo);
|
||||||
requetPrePrepareFromMaster(pbftMessage.order);
|
requestPrePrepareFromMaster(pbftMessage.order);
|
||||||
} else if (temp.updatePrepare(pbftMessage, this)) {
|
} else if (temp.updatePrepare(pbftMessage, this)) {
|
||||||
// check the sender (is master) and order is in range !!!!
|
// check the sender (is master) and order is in range !!!!
|
||||||
PBFTMessage commitMsg = new PBFTMessage();
|
PBFTMessage commitMsg = new PBFTMessage();
|
||||||
@ -113,7 +127,7 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
PCInfo pcInfo = new PCInfo();
|
PCInfo pcInfo = new PCInfo();
|
||||||
pcInfo.buff.add(pbftMessage);
|
pcInfo.buff.add(pbftMessage);
|
||||||
info.put(pbftMessage.order, pcInfo);
|
info.put(pbftMessage.order, pcInfo);
|
||||||
requetPrePrepareFromMaster(pbftMessage.order);
|
requestPrePrepareFromMaster(pbftMessage.order);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (temp.updateCommit(pbftMessage, this)) {
|
if (temp.updateCommit(pbftMessage, this)) {
|
||||||
@ -177,12 +191,14 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void requetPrePrepareFromMaster(long order) {
|
private void requestPrePrepareFromMaster(long order) {
|
||||||
PBFTMessage message = new PBFTMessage();
|
|
||||||
message.type = PBFTType.ReSend;
|
// PBFTMessage message = new PBFTMessage();
|
||||||
message.order = order;
|
// message.type = PBFTType.ReSend;
|
||||||
message.content = new byte[1];
|
// message.order = order;
|
||||||
sendToMaster(message);
|
// message.content = new byte[1];
|
||||||
|
// sendToMaster(message);
|
||||||
|
LOGGER.info("request Resend");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void matchPrePrepareFromOriginReqeust(int hash, PBFTMessage pbftMessage) {
|
private void matchPrePrepareFromOriginReqeust(int hash, PBFTMessage pbftMessage) {
|
||||||
@ -239,7 +255,7 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
PBFTMessage original = getOriginalMessage(pbftMessage.order);
|
PBFTMessage original = getOriginalMessage(pbftMessage.order);
|
||||||
// execute(pbftMessage);
|
// execute(pbftMessage);
|
||||||
if (pbftMessage.order == commitedOrder.get() + 1) {
|
if (pbftMessage.order == commitedOrder.get() + 1) {
|
||||||
execute(original);
|
execute(pbftMessage);
|
||||||
} else {
|
} else {
|
||||||
commitedMsg.add(original);
|
commitedMsg.add(original);
|
||||||
}
|
}
|
||||||
@ -247,11 +263,13 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
|
|
||||||
private synchronized void execute(PBFTMessage pbftMessage) {
|
private synchronized void execute(PBFTMessage pbftMessage) {
|
||||||
commitedOrder.incrementAndGet();
|
commitedOrder.incrementAndGet();
|
||||||
|
LOGGER.info("execute:" + pbftMessage + " infoKeySet:" + JsonUtil.toJson(info.keySet()));
|
||||||
|
|
||||||
|
|
||||||
PBFTMessage original = getOriginalMessage(pbftMessage.order);
|
PBFTMessage original = getOriginalMessage(pbftMessage.order);
|
||||||
ContractRequest msg = ContractRequest.parse(original.content);
|
ContractRequest msg = ContractRequest.parse(original.content);
|
||||||
committer.onCommit(msg);
|
committer.onCommit(msg);
|
||||||
|
|
||||||
System.out.println(": execute, " + JsonUtil.toJson(msg));
|
|
||||||
info.remove(pbftMessage.order);
|
info.remove(pbftMessage.order);
|
||||||
// ContractProcess.instance.onEvent(msg);
|
// ContractProcess.instance.onEvent(msg);
|
||||||
commitedMsg.sort((o1, o2) -> (int) (o1.order - o2.order));
|
commitedMsg.sort((o1, o2) -> (int) (o1.order - o2.order));
|
||||||
@ -275,17 +293,15 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void broadcast(PBFTMessage pbftMessage) {
|
private void broadcast(PBFTMessage pbftMessage) {
|
||||||
for (Node node : members.keySet()) {
|
pbftMessage.sendID = sendID;
|
||||||
System.out.println("[PBFTAlgorithm] send: " + pbftMessage.getDisplayStr());
|
connection.broadcast(pbftMessage.getBytes());
|
||||||
|
|
||||||
connection.sendMessage(node, pbftMessage.getBytes());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sendToMaster(PBFTMessage pbftMessage) {
|
private void sendToMaster(PBFTMessage pbftMessage) {
|
||||||
for (Node node : members.keySet()) {
|
for (Node node : members.keySet()) {
|
||||||
PBFTMember member = members.get(node);
|
PBFTMember member = members.get(node);
|
||||||
if (member.isMaster) {
|
if (member.isMaster) {
|
||||||
|
pbftMessage.sendID = sendID;
|
||||||
connection.sendMessage(node, pbftMessage.getBytes());
|
connection.sendMessage(node, pbftMessage.getBytes());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -302,6 +318,11 @@ public class PBFTAlgorithm implements CommitAlgorithm {
|
|||||||
onPBFTMessage(node, pbftMessage);
|
onPBFTMessage(node, pbftMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setAtomSeq(int i) {
|
||||||
|
allocatedID.set(i);
|
||||||
|
commitedOrder.set(i);
|
||||||
|
}
|
||||||
|
|
||||||
static class NodeInfo {
|
static class NodeInfo {
|
||||||
SM2KeyPair privKey;
|
SM2KeyPair privKey;
|
||||||
int hash;
|
int hash;
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
package org.bdware.sc.sequencing;
|
package org.bdware.sc.sequencing;
|
||||||
|
|
||||||
|
import org.bdware.sc.conn.ByteUtil;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.bdware.sc.conn.ByteUtil;
|
|
||||||
|
|
||||||
public class PBFTMessage {
|
public class PBFTMessage {
|
||||||
PBFTType type;
|
PBFTType type;
|
||||||
int sendID;
|
int sendID;
|
||||||
@ -96,4 +96,8 @@ public class PBFTMessage {
|
|||||||
sb.append(new String(content));
|
sb.append(new String(content));
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setOrder(long order) {
|
||||||
|
this.order = order;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -120,6 +120,13 @@ public class ContractUnitController {
|
|||||||
// TODO sig here.
|
// TODO sig here.
|
||||||
connection.sendMessage(member.getNode(), unitMsg.toByteArray());
|
connection.sendMessage(member.getNode(), unitMsg.toByteArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List getNodes() {
|
||||||
|
List<Node> ret = new ArrayList<>();
|
||||||
|
ret.addAll(node2member.keySet());
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static class PCInfo {
|
static class PCInfo {
|
||||||
|
7
src/main/java/org/bdware/sc/units/PubKeyNode.java
Normal file
7
src/main/java/org/bdware/sc/units/PubKeyNode.java
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
package org.bdware.sc.units;
|
||||||
|
|
||||||
|
import org.bdware.sc.conn.Node;
|
||||||
|
|
||||||
|
public class PubKeyNode extends Node {
|
||||||
|
public String pubkey;
|
||||||
|
}
|
@ -2,6 +2,15 @@ package org.bdware.sc.units;
|
|||||||
|
|
||||||
import org.bdware.sc.conn.Node;
|
import org.bdware.sc.conn.Node;
|
||||||
|
|
||||||
public interface TrustfulExecutorConnection {
|
import java.util.List;
|
||||||
public void sendMessage(Node node, byte[] msg);
|
|
||||||
|
public interface TrustfulExecutorConnection<T extends Node> {
|
||||||
|
public void sendMessage(T node, byte[] msg);
|
||||||
|
|
||||||
|
default public void broadcast(byte[] msg) {
|
||||||
|
for (T t : getNodes())
|
||||||
|
sendMessage(t, msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<T> getNodes();
|
||||||
}
|
}
|
@ -1,10 +1,14 @@
|
|||||||
package org.bdware.server.trustedmodel;
|
package org.bdware.server.trustedmodel;
|
||||||
|
|
||||||
import org.bdware.sc.bean.ContractRequest;
|
import org.bdware.sc.bean.ContractRequest;
|
||||||
|
import org.bdware.sc.conn.Node;
|
||||||
import org.bdware.sc.conn.OnHashCallback;
|
import org.bdware.sc.conn.OnHashCallback;
|
||||||
import org.bdware.sc.conn.ResultCallback;
|
import org.bdware.sc.conn.ResultCallback;
|
||||||
|
|
||||||
public interface ContractExecutor {
|
public interface ContractExecutor {
|
||||||
void execute(String requestID, ContractRequest req, ResultCallback rcb, OnHashCallback hcb);
|
void execute(String requestID, ContractRequest req, ResultCallback rcb, OnHashCallback hcb);
|
||||||
|
|
||||||
|
default void onSyncMessage(Node node, byte[] data) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user