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


Java Operation類代碼示例

本文整理匯總了Java中edu.uw.zookeeper.protocol.Operation的典型用法代碼示例。如果您正苦於以下問題:Java Operation類的具體用法?Java Operation怎麽用?Java Operation使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: Builder

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
protected Builder(
        ZxidGenerator zxids,
        NameTrie<ZNodeNode> data,
        SessionManager sessions,
        ReentrantReadWriteLock lock,
        Watches dataWatches,
        Watches childWatches,
        Function<Long, ? extends NotificationListener<Operation.ProtocolResponse<IWatcherEvent>>> listeners,
        RuntimeModule runtime) {
    this.zxids = zxids;
    this.data = data;
    this.sessions = sessions;
    this.dataWatches = dataWatches;
    this.childWatches = childWatches;
    this.runtime = runtime;
    this.listeners = listeners;
    this.lock = lock;
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:19,代碼來源:SimpleServer.java

示例2: ServerBuilder

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
protected ServerBuilder(
        ServerConnectionFactoryBuilder connections,
        SimpleServerSupplier server,
        ConcurrentMap<Long, SimpleSessionExecutor> sessionExecutors,
        ZxidGenerator zxids,
        NameTrie<ZNodeNode> data,
        SessionManager sessions,
        ReentrantReadWriteLock lock,
        Watches dataWatches,
        Watches childWatches,
        Function<Long, ? extends NotificationListener<Operation.ProtocolResponse<IWatcherEvent>>> listeners,
        RuntimeModule runtime) {
    super(zxids, data, sessions, lock, dataWatches, childWatches, listeners, runtime);
    this.connections = checkNotNull(connections);
    this.server = checkNotNull(server);
    this.sessionExecutors = sessionExecutors;
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:18,代碼來源:SimpleServerExecutor.java

示例3: post

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
public void post(final IWatcherEvent event) {
    if (logger.isDebugEnabled()) {
        logger.debug("{}", WatchEvent.fromRecord(event));
    }
    final ProtocolResponseMessage<IWatcherEvent> message = ProtocolResponseMessage.of(
            OpCodeXid.NOTIFICATION.xid(), 
            OpCodeXid.NOTIFICATION_ZXID,
            event);
    String path = event.getPath();
    for (Long session: byPath.removeAll(path)) {
        bySession.remove(session, path);
        NotificationListener<Operation.ProtocolResponse<IWatcherEvent>> listener = listeners.apply(session);
        if (listener != null) {
            listener.handleNotification(message);
        }
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:18,代碼來源:Watches.java

示例4: run

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
public synchronized void run() {
    if (!isDone()) {
        // note that iterator calls are potentially blocking
        if (task().hasNext()) {
            Pair<? extends Records.Request, ? extends ListenableFuture<? extends Operation.ProtocolResponse<?>>> operation;
            try {
                operation = task().next();
            } catch (Exception e) {
                setException(e);
                return;
            }
            pending.incrementAndGet();
            new PendingOperation(operation.second());
            executor.execute(this);
        } else if (pending.get() == 0) {
            set(null);
        }
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:21,代碼來源:IteratingClient.java

示例5: handleConnectionRead

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
public void handleConnectionRead(Operation.Response message) {
    if (message instanceof Message.ServerResponse<?>) {
        int xid = ((Message.ServerResponse<?>) message).xid();
        if (! ((xid == OpCodeXid.PING.xid()) || (xid == OpCodeXid.NOTIFICATION.xid()))) {
            Iterator<T> tasks = mailbox.iterator();
            T task = null;
            while (tasks.hasNext()) {
                T next = tasks.next();
                if ((next.xid() == xid) && !next.isDone()) {
                    task = next;
                    break;
                }
            }
            if (task != null) {
                task.set((Message.ServerResponse<?>) message);
            } else if (state() != State.TERMINATED) {
                // This could happen if someone submitted a message without
                // going through us
                // or, it could be a bug
                logger.warn("{} xid doesn't match {} ({})", message, mailbox.peek(), this);
            }
        }
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:26,代碼來源:PendingQueueClientExecutor.java

示例6: encode

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
/**
 * Don't call concurrently!
 */
@Override
public void encode(Message.ClientSession input, ByteBuf output) throws IOException {
    encoder.encode(input, output);
    automaton.apply(input);
    // we only need to remember xid -> opcode of pending messages
    if (input instanceof Operation.RequestId) {
        int xid = ((Operation.RequestId) input).xid();
        if (! OpCodeXid.has(xid)) {
            assert (input instanceof Operation.ProtocolRequest);
            OpCode opcode = ((Operation.ProtocolRequest<?>) input).record().opcode();
            Pair<Integer, OpCode> pair = Pair.create(xid, opcode);
            pending.add(pair);
        }
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:19,代碼來源:ClientProtocolCodec.java

示例7: decode

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
/**
 * Don't call concurrently!
 */
@Override
public Optional<Message.ServerSession> decode(ByteBuf input)
        throws IOException {
    Optional<Message.ServerSession> out =  decoder.decode(input);
    if (out.isPresent()) {
        automaton.apply(out.get());
        Message.ServerSession reply = out.get();
        // the peek and poll need to be atomic
        Pair<Integer, OpCode> next = pending.peek();
        if ((next != null) && (reply instanceof Operation.RequestId)) {
            if (next.first().equals(((Operation.RequestId) reply).xid())) {
                pending.poll();
            }
        }
    }
    return out;
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:21,代碼來源:ClientProtocolCodec.java

示例8: AbstractConnectionClientExecutor

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
protected AbstractConnectionClientExecutor(
        ListenableFuture<ConnectMessage.Response> session,
        C connection,
        Listeners listeners,
        TimeOutServer<Operation.Response> timer,
        AtomicReference<Throwable> failure) {
    this.session = session;
    this.connection = connection;
    this.listeners = listeners;
    this.timer = timer;
    this.failure = failure;

    new TimeOutListener();
    Futures.addCallback(this.session, this.timer);
    this.connection.subscribe(this);
    this.connection.codec().subscribe(this);
    this.timer.run();
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:19,代碼來源:AbstractConnectionClientExecutor.java

示例9: create

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
public static <I extends Operation.Request, O, T extends CodecConnection<? super I, ? extends O,? extends ProtocolCodec<?,?,?,?>,?>> ClientPingTask<I,O,T> create(
        T connection,
        TimeOutParameters parameters,
        ScheduledExecutorService executor) {
    Logger logger = LogManager.getLogger(ClientPingTask.class);
    ClientPingTask<I,O,T> task = new ClientPingTask<I,O,T>(
            connection,
            parameters, 
            executor,
            Sets.<Pair<Runnable,Executor>>newHashSet(),
            SettableFuturePromise.<Void>create(),
            logger);
    LoggingFutureListener.listen(logger, task);
    // TODO: replay connection events?
    return task;
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:17,代碼來源:PingingClient.java

示例10: defaults

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
public static <C extends ProtocolConnection<? super Message.ClientSession, ? extends Operation.Response,?,?,?>> ServerViewFactory<Session, OperationClientExecutor<C>> defaults(
        ClientConnectionFactory<C> connections,
        ServerInetAddressView view,
        TimeValue timeOut,
        ScheduledExecutorService executor) {
    ZxidTracker zxids = ZxidTracker.zero();
    final DefaultsFactory<Session, ConnectMessage.Request> requestFactory = ConnectMessage.Request.factory(timeOut, zxids);
    final FromRequestFactory<C> delegate = 
            FromRequestFactory.create(
                    FixedClientConnectionFactory.create(view.get(), connections),
                    executor);
    return new ServerViewFactory<Session, OperationClientExecutor<C>>(
            view,
            new DefaultsFactory<Session, ListenableFuture<? extends OperationClientExecutor<C>>>() {
                @Override
                public ListenableFuture<OperationClientExecutor<C>> get() {
                    return delegate.get(requestFactory.get());
                }

                @Override
                public ListenableFuture<OperationClientExecutor<C>> get(Session value) {
                    return delegate.get(requestFactory.get(value));
                }
            }, 
            zxids);
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:27,代碼來源:ServerViewFactory.java

示例11: deleteChildren

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
public static ListenableFuture<List<AbsoluteZNodePath>> deleteChildren(
        final ZNodePath parent, 
        final ClientExecutor<? super Records.Request, ? extends Operation.ProtocolResponse<?>, ?> client) {
    return Futures.transform(
            GetChildren.create(
                    parent, 
                    client, 
                    SettableFuturePromise.<List<AbsoluteZNodePath>>create()), 
            new AsyncFunction<List<AbsoluteZNodePath>, List<AbsoluteZNodePath>>() {
                @Override
                public ListenableFuture<List<AbsoluteZNodePath>> apply(
                        List<AbsoluteZNodePath> children) throws Exception {
                    ImmutableList.Builder<ListenableFuture<AbsoluteZNodePath>> deletes = ImmutableList.builder();
                    for (AbsoluteZNodePath child: children) {
                        deletes.add(DeleteSubtree.deleteAll(child, client));
                    }
                    return Futures.allAsList(deletes.build());
                }
            });
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:21,代碼來源:DeleteSubtree.java

示例12: onSuccess

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
public synchronized void onSuccess(DeleteLeaf result) {
    checkArgument(result.isDone());
    deletes.remove(this);
    if (!result.isCancelled()) {
        try {
            for (Operation.ProtocolResponse<?> response: result.get()) {
                Operations.maybeError(response.record(), KeeperException.Code.NONODE);
            }
        } catch (Exception e) {
            onFailure(e);
        }
        Node parent = result.node().parent().get();
        if (result.node().remove() && (parent != null) && (parent.isEmpty())) {
            if (parent.path().length() >= root.length()) {
                delete(parent);
            } else {
                // done!
                promise.set(root);
            }
        }
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:24,代碼來源:DeleteSubtree.java

示例13: call

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
public Optional<List<AbsoluteZNodePath>> call() throws Exception {
    if (requests.isDone()) {
        List<? extends Operation.ProtocolResponse<?>> responses = requests.get();
        ImmutableList.Builder<AbsoluteZNodePath> children = ImmutableList.builder();
        for (int i=0; i<requests.getValue().size(); ++i) {
            Operation.ProtocolResponse<?> response = responses.get(i);
            if (!Operations.maybeError(response.record(), KeeperException.Code.NONODE).isPresent()) {
                if (response.record() instanceof Records.ChildrenGetter) {
                    ZNodePath prefix = ZNodePath.fromString(((Records.PathGetter) requests.getValue().get(i)).getPath());
                    for (String child: ((Records.ChildrenGetter) response.record()).getChildren()) {
                        children.add((AbsoluteZNodePath) prefix.join(ZNodeLabel.fromString(child)));
                    }
                }
            }
        }
        return Optional.<List<AbsoluteZNodePath>>of(children.build());
    } else {
        return Optional.absent();
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:22,代碼來源:DeleteSubtree.java

示例14: getDefaultConnectionClientExecutorsService

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
protected ConnectionClientExecutorsService<Operation.Request, Session, OperationClientExecutor<?>> getDefaultConnectionClientExecutorsService() {
    EnsembleView<ServerInetAddressView> ensemble = EnsembleViewConfiguration.get(getRuntimeModule().getConfiguration());
    final EnsembleViewFactory<? extends ServerViewFactory<Session, ? extends OperationClientExecutor<?>>> ensembleFactory = 
            EnsembleViewFactory.fromSession(
                getClientConnectionFactory(),
                ensemble, 
                getConnectionBuilder().getTimeOut(),
                getRuntimeModule().getExecutors().get(ScheduledExecutorService.class));
    ConnectionClientExecutorsService<Operation.Request, Session, OperationClientExecutor<?>> service =
            ConnectionClientExecutorsService.newInstance(
                    new DefaultsFactory<Session, ListenableFuture<? extends OperationClientExecutor<?>>>() {
                        @Override
                        public ListenableFuture<? extends OperationClientExecutor<?>> get(Session value) {
                            return ensembleFactory.get().get(value);
                        }
                        @Override
                        public ListenableFuture<? extends OperationClientExecutor<?>> get() {
                            return ensembleFactory.get().get();
                        }
                    });
    return service;
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:24,代碼來源:ConnectionClientExecutorsService.java

示例15: handleNotification

import edu.uw.zookeeper.protocol.Operation; //導入依賴的package包/類
@Override
public void handleNotification(
        Operation.ProtocolResponse<IWatcherEvent> notification) {
    for (SessionListener listener: listeners) {
        listener.handleNotification(notification);
    }
}
 
開發者ID:lisaglendenning,項目名稱:zookeeper-lite,代碼行數:8,代碼來源:AbstractSessionExecutor.java


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