本文整理了Java中org.jgroups.util.Util.pickRandomElement()
方法的一些代码示例,展示了Util.pickRandomElement()
的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。Util.pickRandomElement()
方法的具体详情如下:
包路径:org.jgroups.util.Util
类名称:Util
方法名:pickRandomElement
暂无
代码示例来源:origin: wildfly/wildfly
private Address pickTarget() {
return Util.pickRandomElement(dests);
}
代码示例来源:origin: wildfly/wildfly
/**
* Applies action to a randomly picked RouterStub that's connected
* @param action
*/
public void forAny(Consumer<RouterStub> action) {
while(!stubs.isEmpty()) {
RouterStub stub=Util.pickRandomElement(stubs);
if(stub != null && stub.isConnected()) {
action.accept(stub);
return;
}
}
}
代码示例来源:origin: wildfly/wildfly
protected void retransmit(SeqnoList missing_msgs, final Address sender, boolean multicast_xmit_request) {
Address dest=(multicast_xmit_request || this.use_mcast_xmit_req)? null : sender; // to whom do we send the XMIT request ?
if(xmit_from_random_member && !local_addr.equals(sender)) {
Address random_member=Util.pickRandomElement(members);
if(random_member != null && !local_addr.equals(random_member))
dest=random_member;
}
Message retransmit_msg=new Message(dest).setBuffer(Util.streamableToBuffer(missing_msgs))
.setFlag(Message.Flag.OOB, Message.Flag.INTERNAL)
.putHeader(this.id, NakAckHeader2.createXmitRequestHeader(sender));
log.trace("%s: sending XMIT_REQ (%s) to %s", local_addr, missing_msgs, dest);
down_prot.down(retransmit_msg);
if(stats)
xmit_reqs_sent.add(missing_msgs.size());
}
代码示例来源:origin: wildfly/wildfly
public void start(String props, String name, boolean unicast) throws Exception {
ch=new JChannel(props);
if(name != null)
ch.setName(name);
ch.setReceiver(this);
ch.connect("ping");
while(true) {
Util.keyPress("enter to ping");
Address dest=null;
if(unicast)
dest=Util.pickRandomElement(members);
Message msg=new Message(dest, PING_REQ);
msg.setFlag(Message.Flag.DONT_BUNDLE, Message.Flag.NO_FC);
start=System.nanoTime();
ch.send(msg);
}
}
代码示例来源:origin: wildfly/wildfly
/** Called to handle a message received by the relayer */
protected void handleRelayMessage(Relay2Header hdr, Message msg) {
if(hdr.final_dest != null) {
Message message=msg;
Relay2Header header=hdr;
if(header.type == Relay2Header.DATA && can_forward_local_cluster) {
SiteUUID site_uuid=(SiteUUID)hdr.final_dest;
// If configured to do so, we want to load-balance these messages,
UUID tmp=(UUID)Util.pickRandomElement(members);
SiteAddress final_dest=new SiteUUID(tmp, site_uuid.getName(), site_uuid.getSite());
// If we select a different address to handle this message, we handle it here.
if(!final_dest.equals(hdr.final_dest)) {
message=copy(msg);
header=new Relay2Header(Relay2Header.DATA, final_dest, hdr.original_sender );
message.putHeader(id, header);
}
}
handleMessage(header, message);
}
else {
Message copy=copy(msg).dest(null).src(null).putHeader(id, hdr);
down_prot.down(copy); // multicast locally
// Don't forward: https://issues.jboss.org/browse/JGRP-1519
// sendToBridges(msg.getSrc(), buf, from_site, site_id); // forward to all bridges except self and from
}
}
代码示例来源:origin: org.jboss.eap/wildfly-client-all
private Address pickTarget() {
return Util.pickRandomElement(dests);
}
代码示例来源:origin: org.jboss.eap/wildfly-client-all
/**
* Applies action to a randomly picked RouterStub that's connected
* @param action
*/
public void forAny(Consumer<RouterStub> action) {
while(!stubs.isEmpty()) {
RouterStub stub=Util.pickRandomElement(stubs);
if(stub != null && stub.isConnected()) {
action.accept(stub);
return;
}
}
}
代码示例来源:origin: org.jgroups/com.springsource.org.jgroups
Address random_member=(Address)Util.pickRandomElement(members);
if(random_member != null && !local_addr.equals(random_member)) {
dest=random_member;
代码示例来源:origin: org.jboss.eap/wildfly-client-all
protected void retransmit(SeqnoList missing_msgs, final Address sender, boolean multicast_xmit_request) {
Address dest=(multicast_xmit_request || this.use_mcast_xmit_req)? null : sender; // to whom do we send the XMIT request ?
if(xmit_from_random_member && !local_addr.equals(sender)) {
Address random_member=Util.pickRandomElement(members);
if(random_member != null && !local_addr.equals(random_member))
dest=random_member;
}
Message retransmit_msg=new Message(dest).setBuffer(Util.streamableToBuffer(missing_msgs))
.setFlag(Message.Flag.OOB, Message.Flag.INTERNAL)
.putHeader(this.id, NakAckHeader2.createXmitRequestHeader(sender));
log.trace("%s: sending XMIT_REQ (%s) to %s", local_addr, missing_msgs, dest);
down_prot.down(retransmit_msg);
if(stats)
xmit_reqs_sent.add(missing_msgs.size());
}
代码示例来源:origin: org.jboss.eap/wildfly-client-all
public void start(String props, String name, boolean unicast) throws Exception {
ch=new JChannel(props);
if(name != null)
ch.setName(name);
ch.setReceiver(this);
ch.connect("ping");
while(true) {
Util.keyPress("enter to ping");
Address dest=null;
if(unicast)
dest=Util.pickRandomElement(members);
Message msg=new Message(dest, PING_REQ);
msg.setFlag(Message.Flag.DONT_BUNDLE, Message.Flag.NO_FC);
start=System.nanoTime();
ch.send(msg);
}
}
代码示例来源:origin: org.jboss.eap/wildfly-client-all
/** Called to handle a message received by the relayer */
protected void handleRelayMessage(Relay2Header hdr, Message msg) {
if(hdr.final_dest != null) {
Message message=msg;
Relay2Header header=hdr;
if(header.type == Relay2Header.DATA && can_forward_local_cluster) {
SiteUUID site_uuid=(SiteUUID)hdr.final_dest;
// If configured to do so, we want to load-balance these messages,
UUID tmp=(UUID)Util.pickRandomElement(members);
SiteAddress final_dest=new SiteUUID(tmp, site_uuid.getName(), site_uuid.getSite());
// If we select a different address to handle this message, we handle it here.
if(!final_dest.equals(hdr.final_dest)) {
message=copy(msg);
header=new Relay2Header(Relay2Header.DATA, final_dest, hdr.original_sender );
message.putHeader(id, header);
}
}
handleMessage(header, message);
}
else {
Message copy=copy(msg).dest(null).src(null).putHeader(id, hdr);
down_prot.down(copy); // multicast locally
// Don't forward: https://issues.jboss.org/browse/JGRP-1519
// sendToBridges(msg.getSrc(), buf, from_site, site_id); // forward to all bridges except self and from
}
}
内容来源于网络,如有侵权,请联系作者删除!