本文整理汇总了Java中org.jgroups.View.getMembers方法的典型用法代码示例。如果您正苦于以下问题:Java View.getMembers方法的具体用法?Java View.getMembers怎么用?Java View.getMembers使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.jgroups.View
的用法示例。
在下文中一共展示了View.getMembers方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
public void viewAccepted(View new_view) {
nodes.clear();
for(Address node: new_view.getMembers()) {
int hash=Math.abs(node.hashCode() & (HASH_SPACE - 1));
for(int i=hash; i < hash + HASH_SPACE; i++) {
short new_index=(short)(i & (HASH_SPACE - 1));
if(!nodes.containsKey(new_index)) {
nodes.put(new_index, node);
break;
}
}
}
if(log.isTraceEnabled()) {
StringBuilder sb=new StringBuilder("node mappings:\n");
for(Map.Entry<Short,Address> entry: nodes.entrySet()) {
sb.append(entry.getKey() + ": " + entry.getValue()).append("\n");
}
log.trace(sb);
}
}
示例2: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
@Override
public void viewAccepted(View newView) {
if (newView.getMembers() != null) {
synchronized (remoteMembers) {
remoteMembers.removeAll(newView.getMembers());
if (object instanceof ReplicatedObject<?> && !remoteMembers.isEmpty()) {
HashSet<Serializable> dropped = new HashSet<Serializable>();
for (Address address : remoteMembers) {
dropped.add(new AddressWrapper(address));
}
((ReplicatedObject<?>)object).droppedMembers(dropped);
}
remoteMembers.clear();
remoteMembers.addAll(newView.getMembers());
remoteMembers.remove(this.disp.getChannel().getAddress());
}
}
}
示例3: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
@Override
public void viewAccepted(View view) {
log.info("Members changed: {}", view.getMembers());
synchronized (addresses) {
addresses.clear();
for (Address address: view.getMembers()) {
System.out.println(address.getClass().getCanonicalName());
addresses.put(address.toString(), address);
}
}
try {
log.trace("ViewId: {}", mapper.writeValueAsString(view));
} catch (IOException e) {
e.printStackTrace();
}
}
示例4: print
import org.jgroups.View; //导入方法依赖的package包/类
static String print(View view) {
StringBuilder sb=new StringBuilder();
boolean first=true;
sb.append(view.getClass().getSimpleName() + ": ").append(view.getViewId()).append(": ");
for(Address mbr: view.getMembers()) {
if(first)
first=false;
else
sb.append(", ");
sb.append(mbr);
}
return sb.toString();
}
示例5: handleView
import org.jgroups.View; //导入方法依赖的package包/类
protected void handleView(View view) {
List<Address> view_mbrs=view.getMembers();
boolean is_pinger=false;
members.clear();
members.addAll(view_mbrs);
Collection<InetAddress> current_hosts=null;
synchronized(hosts) {
hosts.clear();
for(Address mbr: view_mbrs) {
InetAddress key=getHostFor(mbr);
if(key == null)
continue;
List<Address> mbrs=hosts.get(key);
if(mbrs == null)
hosts.put(key, mbrs=new ArrayList<>());
mbrs.add(mbr);
}
is_pinger=isPinger(local_addr);
current_hosts=new ArrayList<>(hosts.keySet());
}
if(suspected_mbrs.retainAll(view.getMembers()))
has_suspected_mbrs=!suspected_mbrs.isEmpty();
timestamps.keySet().retainAll(current_hosts);
current_hosts.remove(local_host);
for(InetAddress host: current_hosts)
timestamps.putIfAbsent(host, getTimestamp());
if(is_pinger)
startPingerTask();
else {
stopPingerTask();
timestamps.clear();
}
}
示例6: handleView
import org.jgroups.View; //导入方法依赖的package包/类
public void handleView(View view) {
super.handleView(view);
List<Address> members=view.getMembers();
for(Map<Owner,ClientLock> map: client_lock_table.values()) {
for(ClientLock lock: map.values())
((PeerLock)lock).retainAll(members);
}
}
示例7: handleViewChange
import org.jgroups.View; //导入方法依赖的package包/类
private void handleViewChange(View view) {
List<Address> new_mbrs=view.getMembers();
List<Address> left_mbrs=Util.determineLeftMembers(members, new_mbrs);
members.clear();
members.addAll(new_mbrs);
for(Address mbr: left_mbrs){
// the new view doesn't contain the sender, it must have left,
// hence we will clear all of itsfragmentation tables
fragment_list.remove(mbr);
if(log.isTraceEnabled())
log.trace("[VIEW_CHANGE] removed " + mbr + " from fragmentation table");
}
}
示例8: handleViewChange
import org.jgroups.View; //导入方法依赖的package包/类
protected void handleViewChange(View view) {
List<Address> new_mbrs=view.getMembers();
List<Address> left_mbrs=Util.determineLeftMembers(members, new_mbrs);
members.clear();
members.addAll(new_mbrs);
for(Address mbr: left_mbrs) {
// the new view doesn't contain the sender, it must have left, hence we will clear its fragmentation tables
fragment_list.remove(mbr);
log.trace("%s: removed %s from fragmentation table", local_addr, mbr);
}
}
示例9: handleViewChange
import org.jgroups.View; //导入方法依赖的package包/类
private void handleViewChange(View view) {
List<Address> members=view.getMembers();
Set tmp=new LinkedHashSet(members);
tmp.add(null); // for null destination (= mcast)
sent.keySet().retainAll(tmp);
received.keySet().retainAll(tmp);
}
示例10: viewChange
import org.jgroups.View; //导入方法依赖的package包/类
/**
* Any member of 'membership' that is not in the new view is flagged as
* SUSPECTED. Any member in the new view that is <em>not</em> in the
* membership (ie, the set of responses expected for the current RPC) will
* <em>not</em> be added to it. If we did this we might run into the
* following problem:
* <ul>
* <li>Membership is {A,B}
* <li>A sends a synchronous group RPC (which sleeps for 60 secs in the
* invocation handler)
* <li>C joins while A waits for responses from A and B
* <li>If this would generate a new view {A,B,C} and if this expanded the
* response set to {A,B,C}, A would wait forever on C's response because C
* never received the request in the first place, therefore won't send a
* response.
* </ul>
*/
public void viewChange(View new_view) {
if(new_view == null || requests == null || requests.isEmpty())
return;
List<Address> mbrs=new_view.getMembers();
if(mbrs == null)
return;
boolean changed=false;
lock.lock();
try {
for(Map.Entry<Address,Rsp<T>> entry: requests.entrySet()) {
Address mbr=entry.getKey();
// SiteAddresses are not checked as they might be in a different cluster
if(!(mbr instanceof SiteAddress) && !mbrs.contains(mbr)) {
Rsp<T> rsp=entry.getValue();
if(rsp.setSuspected()) {
if(!(rsp.wasReceived() || rsp.wasUnreachable()))
num_received++;
changed=true;
}
}
}
if(changed)
cond.signal(true);
}
finally {
lock.unlock();
}
if(changed)
checkCompletion(this);
}
示例11: testMethodInvocationToNonExistingMembers
import org.jgroups.View; //导入方法依赖的package包/类
/**
* Tests a method call to {A,B,C} where C left *before* the call. http://jira.jboss.com/jira/browse/JGRP-620
*/
public void testMethodInvocationToNonExistingMembers() throws Exception {
final int timeout = 5 * 1000 ;
// get the current membership, as seen by C
View view=c.getView();
List<Address> members=view.getMembers();
System.out.println("list is " + members);
// cause C to leave the group and close its channel
System.out.println("closing c3");
c.close();
Util.sleep(1000);
// make an RPC call using C's now outdated view of membership
System.out.println("calling method foo() in " + members + " (view=" + b.getView() + ")");
RspList<Object> rsps=disp1.callRemoteMethods(members, "foo", null, null, new RequestOptions(ResponseMode.GET_ALL, timeout));
// all responses
System.out.println("responses:\n" + rsps);
for(Map.Entry<Address,Rsp<Object>> entry: rsps.entrySet()) {
Rsp rsp=entry.getValue();
Util.assertTrue("response from " + entry.getKey() + " was not received", rsp.wasReceived());
Util.assertFalse(rsp.wasSuspected());
}
}
示例12: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
@Override
public void viewAccepted(View view)
{
super.viewAccepted(view);
for (Address address: view.getMembers())
{
System.out.println(address);
}
System.out.printf("Number of members %s\n", view.getMembers().size());
}
示例13: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
/**
* This method is invoked by the cluster infrastructure whenever
* a member joins or abandons the cluster group.
*
* @param membershipView Snapshot of members of the cluster.
*/
public void viewAccepted(View membershipView)
{
synchronized(this)
{
Vector<Address> currentMemberList = membershipView.getMembers();
handleArrivingMembers(currentMemberList);
handleDepartedMembers(membershipView, currentMemberList);
}
}
示例14: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
@Override
public void viewAccepted(View new_view) {
Log.i(TAG, "** view: " + new_view);
int peersNumber = new_view.size();
if (peersNumber > 1) {
List<Address> members = new_view.getMembers();
peersIpAddress.clear();
peers.clear();
for (Address a : members) {
String addr = ((Object) a).toString();
Log.i(TAG, "members:" + addr);
// if (!addr.equalsIgnoreCase(localIpAddress)) {
peersIpAddress.add(a);
LanPlayer lanPlayer = new LanPlayer();
lanPlayer.setIp(addr);
lanPlayer.setUsername(channel.getName(a));
lanPlayer.setId(channel.getName(a));
peers.put(addr, lanPlayer);
// }
}
}
LanUtils.sendUpdatePlayerInfoMsg();
}
示例15: viewAccepted
import org.jgroups.View; //导入方法依赖的package包/类
@Override
public void viewAccepted(View view)
{
if (trace)
{
log.tracef("java.net.preferIPv4Stack=%s", SecurityActions.getSystemProperty("java.net.preferIPv4Stack"));
log.tracef("viewAccepted called w/ View=%s", view);
}
synchronized (this)
{
for (org.jgroups.Address physicalAddress : nodes.values())
{
if (physicalAddress != null && !view.containsMember(physicalAddress))
{
leave(physicalAddress);
}
}
for (org.jgroups.Address address : view.getMembers())
{
if (channel != null && !channel.getAddress().equals(address) && !nodes.containsValue(address))
{
try
{
Set<org.ironjacamar.core.spi.workmanager.Address> logicalAddresses =
(Set<org.ironjacamar.core.spi.workmanager.Address>)sendMessage(address, Request.GET_WORKMANAGERS);
if (logicalAddresses != null && !logicalAddresses.isEmpty())
{
for (org.ironjacamar.core.spi.workmanager.Address logicalAddress : logicalAddresses)
{
join(logicalAddress, address);
Long shortRunning = getShortRunningFree(logicalAddress);
Long longRunning = getLongRunningFree(logicalAddress);
localUpdateShortRunningFree(logicalAddress, shortRunning);
localUpdateLongRunningFree(logicalAddress, longRunning);
}
}
}
catch (Throwable t)
{
log.error("ViewAccepted: " + t.getMessage(), t);
}
}
}
}
}