當前位置: 首頁>>代碼示例>>Java>>正文


Java CreateMode.isSequential方法代碼示例

本文整理匯總了Java中org.apache.zookeeper.CreateMode.isSequential方法的典型用法代碼示例。如果您正苦於以下問題:Java CreateMode.isSequential方法的具體用法?Java CreateMode.isSequential怎麽用?Java CreateMode.isSequential使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.zookeeper.CreateMode的用法示例。


在下文中一共展示了CreateMode.isSequential方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: create

import org.apache.zookeeper.CreateMode; //導入方法依賴的package包/類
/**
 * <pre>
 * 1. 使用zookeeper過程,針對出現ConnectionLoss異常,比如進行create/setData/delete,操作可能已經在zookeeper server上進行應用
 * 2. 針對SelectStageListener進行processId創建時,會以最後一次創建的processId做為調度id. 如果進行retry,之前成功的processId就會被遺漏了
 * </pre>
 * 
 * @see org.apache.zookeeper.ZooKeeper#create(String path, byte[] path, List acl, CreateMode mode)
 */
public String create(final String path, final byte[] data, final CreateMode mode) throws KeeperException,
                                                                                 InterruptedException {
    if (mode.isSequential()) {
        return zookeeper.create(path, data, acl, mode);
    } else {
        return retryOperation(new ZooKeeperOperation<String>() {

            public String execute() throws KeeperException, InterruptedException {
                return zookeeper.create(path, data, acl, mode);
            }
        });
    }

}
 
開發者ID:luoyaogui,項目名稱:otter-G,代碼行數:23,代碼來源:ZooKeeperx.java

示例2: pRequest2TxnCreate

import org.apache.zookeeper.CreateMode; //導入方法依賴的package包/類
private void pRequest2TxnCreate(int type, Request request, Record record, boolean deserialize) throws IOException, KeeperException {
    if (deserialize) {
        ByteBufferInputStream.byteBuffer2Record(request.request, record);
    }

    int flags;
    String path;
    List<ACL> acl;
    byte[] data;
    long ttl;
    if (type == OpCode.createTTL) {
        CreateTTLRequest createTtlRequest = (CreateTTLRequest)record;
        flags = createTtlRequest.getFlags();
        path = createTtlRequest.getPath();
        acl = createTtlRequest.getAcl();
        data = createTtlRequest.getData();
        ttl = createTtlRequest.getTtl();
    } else {
        CreateRequest createRequest = (CreateRequest)record;
        flags = createRequest.getFlags();
        path = createRequest.getPath();
        acl = createRequest.getAcl();
        data = createRequest.getData();
        ttl = -1;
    }
    CreateMode createMode = CreateMode.fromFlag(flags);
    validateCreateRequest(path, createMode, request, ttl);
    String parentPath = validatePathForCreate(path, request.sessionId);

    List<ACL> listACL = fixupACL(path, request.authInfo, acl);
    ChangeRecord parentRecord = getRecordForPath(parentPath);

    checkACL(zks, request.cnxn, parentRecord.acl, ZooDefs.Perms.CREATE, request.authInfo, path, listACL);
    int parentCVersion = parentRecord.stat.getCversion();
    if (createMode.isSequential()) {
        path = path + String.format(Locale.ENGLISH, "%010d", parentCVersion);
    }
    validatePath(path, request.sessionId);
    try {
        if (getRecordForPath(path) != null) {
            throw new KeeperException.NodeExistsException(path);
        }
    } catch (KeeperException.NoNodeException e) {
        // ignore this one
    }
    boolean ephemeralParent = EphemeralType.get(parentRecord.stat.getEphemeralOwner()) == EphemeralType.NORMAL;
    if (ephemeralParent) {
        throw new KeeperException.NoChildrenForEphemeralsException(path);
    }
    int newCversion = parentRecord.stat.getCversion()+1;
    if (type == OpCode.createContainer) {
        request.setTxn(new CreateContainerTxn(path, data, listACL, newCversion));
    } else if (type == OpCode.createTTL) {
        request.setTxn(new CreateTTLTxn(path, data, listACL, newCversion, ttl));
    } else {
        request.setTxn(new CreateTxn(path, data, listACL, createMode.isEphemeral(),
                newCversion));
    }
    StatPersisted s = new StatPersisted();
    if (createMode.isEphemeral()) {
        s.setEphemeralOwner(request.sessionId);
    }
    parentRecord = parentRecord.duplicate(request.getHdr().getZxid());
    parentRecord.childCount++;
    parentRecord.stat.setCversion(newCversion);
    addChangeRecord(parentRecord);
    addChangeRecord(new ChangeRecord(request.getHdr().getZxid(), path, s, 0, listACL));
}
 
開發者ID:didichuxing2,項目名稱:https-github.com-apache-zookeeper,代碼行數:69,代碼來源:PrepRequestProcessor.java


注:本文中的org.apache.zookeeper.CreateMode.isSequential方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。