当前位置: 首页>>代码示例>>Java>>正文


Java Lease类代码示例

本文整理汇总了Java中java.rmi.dgc.Lease的典型用法代码示例。如果您正苦于以下问题:Java Lease类的具体用法?Java Lease怎么用?Java Lease使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


Lease类属于java.rmi.dgc包,在下文中一共展示了Lease类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: activateReference

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Sends the first dirty for a received reference in order to get the
 * appropiate lease time from the server, and then schedules the dirty call
 * for lease renewal. If the first dirty message fails, a clean "strong"
 * message is sent for that remote object. If the first dirty call
 * succeeded, the reference becomes a "live" reference for the client DGC.
 * 
 * @param ref
 *            The reference received inside the stub
 * @return The <code>Endpoint / ObjID</code> pair contained inside the
 *         reference
 * @throws UnmarshalException
 *             If the first dirty call fails
 */
private final Pair<Endpoint, ObjID> activateReference(RemoteRef ref)
        throws UnmarshalException {
    // Get necessary data previously stored during RemoteRef
    // deserialization.
    Pair<Endpoint, ObjID> data = deserializedRemoteRefTable.get(ref);
    if (data == null) {
        throw new UnmarshalException(
                "Impossible to get a stub for this object.");
    }
    Lease lease = sendDirty(data.getFirst(),
            new ObjID[] { data.getSecond() });

    if (lease != null) {
        enqueueDirtyCall(data, lease.getValue());
        liveReferences.put(data, new Long(lease.getValue()));
        return data;
    } else {
        sendClean(data.getFirst(), new ObjID[] { data.getSecond() }, true);
        throw new UnmarshalException(
                "Impossible to get a stub for this object.");
    }
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:37,代码来源:DGCClient.java

示例2: sendDirty

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Sends a dirty call to the DGC of the remote server, and returns the
 * <code>Lease</code> granted by that DGC.
 * 
 * @param ep
 *            The <code>Endpoint</code> where the dirty call will be sent.
 * @param obj
 *            An array containing the object identifiers that will be sent
 *            in the dirty call.
 * @return The <code>Lease</code> returned from the server DGC, or
 *         <code>null</code> if the call has failed.
 */
Lease sendDirty(Endpoint ep, ObjID[] obj) {
	synchronized(dgcObjID) { 
     Lease lease = new Lease(vmID, leaseValue);
     Object[] args = new Object[] { obj, ++sequenceNumber, lease };
     TransportManager tm = TransportManager.getTransportManager();
     Object response;
     try {
         response = tm.invoke(dgcObjID, ep, args, SEND_DIRTY_OP_NUM, true);
         if (response instanceof Lease) {
             if (vmID == null) {
                 vmID = ((Lease) response).getVMID();
             }
             return (Lease) response;
         }
         return null;
     } catch (Exception e) {
         return null;
     }
	}
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:33,代码来源:DGCClient.java

示例3: checkInput

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * ObjectInputFilter to filter DGC input objects.
 * The list of acceptable classes is very short and explicit.
 * The depth and array sizes are limited.
 *
 * @param filterInfo access to class, arrayLength, etc.
 * @return  {@link ObjectInputFilter.Status#ALLOWED} if allowed,
 *          {@link ObjectInputFilter.Status#REJECTED} if rejected,
 *          otherwise {@link ObjectInputFilter.Status#UNDECIDED}
 */
private static ObjectInputFilter.Status checkInput(ObjectInputFilter.FilterInfo filterInfo) {
    if (dgcFilter != null) {
        ObjectInputFilter.Status status = dgcFilter.checkInput(filterInfo);
        if (status != ObjectInputFilter.Status.UNDECIDED) {
            // The DGC filter can override the built-in white-list
            return status;
        }
    }

    if (filterInfo.depth() > DGC_MAX_DEPTH) {
        return ObjectInputFilter.Status.REJECTED;
    }
    Class<?> clazz = filterInfo.serialClass();
    if (clazz != null) {
        while (clazz.isArray()) {
            if (filterInfo.arrayLength() >= 0 && filterInfo.arrayLength() > DGC_MAX_ARRAY_SIZE) {
                return ObjectInputFilter.Status.REJECTED;
            }
            // Arrays are allowed depending on the component type
            clazz = clazz.getComponentType();
        }
        if (clazz.isPrimitive()) {
            // Arrays of primitives are allowed
            return ObjectInputFilter.Status.ALLOWED;
        }
        return (clazz == ObjID.class ||
                clazz == UID.class ||
                clazz == VMID.class ||
                clazz == Lease.class)
                ? ObjectInputFilter.Status.ALLOWED
                : ObjectInputFilter.Status.REJECTED;
    }
    // Not a class, not size limited
    return ObjectInputFilter.Status.UNDECIDED;
}
 
开发者ID:lambdalab-mirror,项目名称:jdk8u-jdk,代码行数:46,代码来源:DGCImpl.java

示例4: leaseFilter

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * ObjectInputFilter to filter DGCClient return value (a Lease).
 * The list of acceptable classes is very short and explicit.
 * The depth and array sizes are limited.
 *
 * @param filterInfo access to class, arrayLength, etc.
 * @return  {@link ObjectInputFilter.Status#ALLOWED} if allowed,
 *          {@link ObjectInputFilter.Status#REJECTED} if rejected,
 *          otherwise {@link ObjectInputFilter.Status#UNDECIDED}
 */
private static ObjectInputFilter.Status leaseFilter(ObjectInputFilter.FilterInfo filterInfo) {

    if (filterInfo.depth() > DGCCLIENT_MAX_DEPTH) {
        return ObjectInputFilter.Status.REJECTED;
    }
    Class<?> clazz = filterInfo.serialClass();
    if (clazz != null) {
        while (clazz.isArray()) {
            if (filterInfo.arrayLength() >= 0 && filterInfo.arrayLength() > DGCCLIENT_MAX_ARRAY_SIZE) {
                return ObjectInputFilter.Status.REJECTED;
            }
            // Arrays are allowed depending on the component type
            clazz = clazz.getComponentType();
        }
        if (clazz.isPrimitive()) {
            // Arrays of primitives are allowed
            return ObjectInputFilter.Status.ALLOWED;
        }
        return (clazz == UID.class ||
                clazz == VMID.class ||
                clazz == Lease.class)
                ? ObjectInputFilter.Status.ALLOWED
                : ObjectInputFilter.Status.REJECTED;
    }
    // Not a class, not size limited
    return ObjectInputFilter.Status.UNDECIDED;
}
 
开发者ID:AdoptOpenJDK,项目名称:openjdk-jdk10,代码行数:38,代码来源:DGCImpl_Stub.java

示例5: schedule

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Shedule the renewing call, taking into consideration that the following
 * lease was granted.
 *
 * @param lease the lease that was granted.
 */
public void schedule(Lease lease)
{
  long value = lease.getValue();

  // Shedule a 10 % earlier because some time is needed for the message
  // to reach the server.
  long reduced = (value * 90)/100;
  if (reduced == 0)
    reduced = value;

  timer.schedule(new LeaseTimerTask(), reduced);
}
 
开发者ID:vilie,项目名称:javify,代码行数:19,代码来源:LeaseRenewingTask.java

示例6: renew

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Renew the lease.
 */
public void renew()
{
  Object renewIt = null;
  // Iterate throw the list of associated references. If all are
  // discarded, there is no need to renew.
  synchronized (ref)
  {
    Iterator iter = ref.iterator();
    WeakReference w;
    while (iter.hasNext() && renewIt == null)
      {
        w = (WeakReference) iter.next();
        renewIt = w.get();
        if (renewIt == null)
          // Discard the weak reference if its target has been garbage
          // collected.
          iter.remove();
      }
  }

  if (renewIt!=null)
    {
      Lease lease = notifyDGC( (UnicastRef) renewIt);

      // Schedule the next renewing session.
      if (lease!=null)
        schedule(lease);
    }
    {
      // All references collected - discard this entry.
    }
}
 
开发者ID:vilie,项目名称:javify,代码行数:36,代码来源:LeaseRenewingTask.java

示例7: notifyDGC

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Notify DGC that we still hold this reference.
 *
 * @param renewIt the reference we still have (must not be null).
 */
public Lease notifyDGC(UnicastRef renewIt)
{
  try
    {
      return renewIt.notifyDGC(lease);
    }
  catch (Exception e)
    {
      // Failed to notify.
      // TODO Take some relevant action in the case if we failed
      // to notify the remote object owner.
      return null;
    }
}
 
开发者ID:vilie,项目名称:javify,代码行数:20,代码来源:LeaseRenewingTask.java

示例8: schedule

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Shedule the renewing call, taking into consideration that the following
 * lease was granted.
 * 
 * @param lease the lease that was granted.
 */
public void schedule(Lease lease)
{
  long value = lease.getValue();
  
  // Shedule a 10 % earlier because some time is needed for the message
  // to reach the server.
  long reduced = (value * 90)/100;
  if (reduced == 0)
    reduced = value;
  
  timer.schedule(new LeaseTimerTask(), reduced);
}
 
开发者ID:nmldiegues,项目名称:jvm-stm,代码行数:19,代码来源:LeaseRenewingTask.java

示例9: renew

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Renew the lease.
 */
public void renew()
{
  Object renewIt = null;
  // Iterate throw the list of associated references. If all are
  // discarded, there is no need to renew.
  synchronized (ref)
  {
    Iterator iter = ref.iterator();
    WeakReference w;
    while (iter.hasNext() && renewIt == null)
      {
        w = (WeakReference) iter.next();
        renewIt = w.get();
        if (renewIt == null)
          // Discard the weak reference if its target has been garbage
          // collected.
          iter.remove();
      }
  }
  
  if (renewIt!=null)
    {
      Lease lease = notifyDGC( (UnicastRef) renewIt);
      
      // Schedule the next renewing session.
      if (lease!=null)
        schedule(lease);
    }
    {
      // All references collected - discard this entry.
    }
}
 
开发者ID:nmldiegues,项目名称:jvm-stm,代码行数:36,代码来源:LeaseRenewingTask.java

示例10: notifyDGC

import java.rmi.dgc.Lease; //导入依赖的package包/类
/**
 * Notify DGC that we still hold this reference.
 * 
 * @param renewIt the reference we still have (must not be null).
 */
public Lease notifyDGC(UnicastRef renewIt)
{
  try
    {
      return renewIt.notifyDGC(lease);
    }
  catch (Exception e)
    {
      // Failed to notify.
      // TODO Take some relevant action in the case if we failed
      // to notify the remote object owner.
      return null;
    }
}
 
开发者ID:nmldiegues,项目名称:jvm-stm,代码行数:20,代码来源:LeaseRenewingTask.java

示例11: dgcDirty

import java.rmi.dgc.Lease; //导入依赖的package包/类
void dgcDirty() {
    ObjID[] ids;

    synchronized (tablesLock) {
        ids = (ObjID[]) renewTable.keySet().toArray(
                new ObjID[renewTable.size()]);
    }

    try {
        Lease lease = dgcStub.dirty(ids, getSeqNumber(),
                new Lease(vmid, DGCImpl.maxDuration));
        failedDirtyCallsNum = 0;
        failureStartTime = 0;
        latestLeaseDuration = lease.getValue();
        renewTime = System.currentTimeMillis()
                + latestLeaseDuration / 2;
    } catch (RemoteException re) {
        // dirty call failed
        long curTime = System.currentTimeMillis();
        ++failedDirtyCallsNum;

        if (failedDirtyCallsNum == 1) {
            failureStartTime = curTime;
            latestLeaseDuration = (latestLeaseDuration > 0)
                    ? latestLeaseDuration : DGCImpl.maxDuration;
            failedRenewBaseDuration = latestLeaseDuration >> 5;
        }
        renewTime = curTime +
            failedRenewBaseDuration * ((failedDirtyCallsNum - 1) << 1);

        if (renewTime > failureStartTime + latestLeaseDuration) {
            renewTime = Long.MAX_VALUE;
        }
    }
}
 
开发者ID:shannah,项目名称:cn1,代码行数:36,代码来源:ClientDGC.java

示例12: testGetValueAndGetVMID

import java.rmi.dgc.Lease; //导入依赖的package包/类
public void testGetValueAndGetVMID() {
	VMID vmid = new VMID();
	long duration = (long) Math.random() * Long.MAX_VALUE;

	Lease lease = new Lease(vmid, duration);

	assertEquals(duration, lease.getValue());
	assertEquals(vmid, lease.getVMID());
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:10,代码来源:LeaseTest.java

示例13: testLease001

import java.rmi.dgc.Lease; //导入依赖的package包/类
public void testLease001() {
    long duration = 0;
    assertNotNull(msgNotNull, new Lease(id, duration));
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:5,代码来源:TestLease.java

示例14: testLease002

import java.rmi.dgc.Lease; //导入依赖的package包/类
public void testLease002() {
    id = new VMID();
    long duration = 0;
    assertNotNull(msgNotNull, new Lease(id, duration));
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:6,代码来源:TestLease.java

示例15: testLease003

import java.rmi.dgc.Lease; //导入依赖的package包/类
public void testLease003() {
    long duration = Long.MAX_VALUE;
    assertNotNull(msgNotNull, new Lease(id, duration));
}
 
开发者ID:freeVM,项目名称:freeVM,代码行数:5,代码来源:TestLease.java


注:本文中的java.rmi.dgc.Lease类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。