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


Java TProtocolUtil.getTSyncOfferMessage方法代码示例

本文整理汇总了Java中org.sdnplatform.sync.internal.rpc.TProtocolUtil.getTSyncOfferMessage方法的典型用法代码示例。如果您正苦于以下问题:Java TProtocolUtil.getTSyncOfferMessage方法的具体用法?Java TProtocolUtil.getTSyncOfferMessage怎么用?Java TProtocolUtil.getTSyncOfferMessage使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.sdnplatform.sync.internal.rpc.TProtocolUtil的用法示例。


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

示例1: antientropy

import org.sdnplatform.sync.internal.rpc.TProtocolUtil; //导入方法依赖的package包/类
/**
 * Perform a synchronization with the node specified
 */
public void antientropy(Node node) {
	if (!rpcService.isConnected(node.getNodeId())) return;

	logger.info("[{}->{}] Synchronizing local state to remote node",
			getLocalNodeId(), node.getNodeId());

	for (SynchronizingStorageEngine store : storeRegistry.values()) {
		if (Scope.LOCAL.equals(store.getScope())) {
			if (node.getDomainId() !=
					getClusterConfig().getNode().getDomainId())
				continue;
		} else if (Scope.UNSYNCHRONIZED.equals(store.getScope())) {
			continue;
		}

		IClosableIterator<Entry<ByteArray,
		List<Versioned<byte[]>>>> entries =
		store.entries();
		try {
			SyncMessage bsm =
					TProtocolUtil.getTSyncOfferMessage(store.getName(),
							store.getScope(),
							store.isPersistent());
			int count = 0;
			while (entries.hasNext()) {
				if (!rpcService.isConnected(node.getNodeId())) return;

				Entry<ByteArray, List<Versioned<byte[]>>> pair =
						entries.next();
				KeyedVersions kv =
						TProtocolUtil.getTKeyedVersions(pair.getKey(),
								pair.getValue());
				bsm.getSyncOffer().addToVersions(kv);
				count += 1;
				if (count >= 50) {
					sendSyncOffer(node.getNodeId(), bsm);
					// realloc sync message - it is still queued up by netty!
					bsm = TProtocolUtil.getTSyncOfferMessage(store.getName(),
							store.getScope(),
							store.isPersistent());
					count = 0;
				}
			}
			sendSyncOffer(node.getNodeId(), bsm);
		} catch (InterruptedException e) {
			// This can't really happen
			throw new RuntimeException(e);
		} finally {
			entries.close();
		}
	}
}
 
开发者ID:xuraylei,项目名称:fresco_floodlight,代码行数:56,代码来源:SyncManager.java

示例2: antientropy

import org.sdnplatform.sync.internal.rpc.TProtocolUtil; //导入方法依赖的package包/类
/**
 * Perform a synchronization with the node specified
 */
@LogMessageDoc(level="INFO",
               message="[{id}->{id}] Synchronizing local state to remote node",
               explanation="Normal state resynchronization is occurring")
public void antientropy(Node node) {
    if (!rpcService.isConnected(node.getNodeId())) return;

    logger.info("[{}->{}] Synchronizing local state to remote node",
                getLocalNodeId(), node.getNodeId());

    for (SynchronizingStorageEngine store : storeRegistry.values()) {
        if (Scope.LOCAL.equals(store.getScope())) {
            if (node.getDomainId() !=
                    getClusterConfig().getNode().getDomainId())
                continue;
        } else if (Scope.UNSYNCHRONIZED.equals(store.getScope())) {
            continue;
        }

        IClosableIterator<Entry<ByteArray,
                              List<Versioned<byte[]>>>> entries =
                store.entries();
        try {
            SyncMessage bsm =
                    TProtocolUtil.getTSyncOfferMessage(store.getName(),
                                                       store.getScope(),
                                                       store.isPersistent());
            int count = 0;
            while (entries.hasNext()) {
                if (!rpcService.isConnected(node.getNodeId())) return;

                Entry<ByteArray, List<Versioned<byte[]>>> pair =
                        entries.next();
                KeyedVersions kv =
                        TProtocolUtil.getTKeyedVersions(pair.getKey(),
                                                        pair.getValue());
                bsm.getSyncOffer().addToVersions(kv);
                count += 1;
                if (count >= 50) {
                    sendSyncOffer(node.getNodeId(), bsm);
                    bsm.getSyncOffer().unsetVersions();
                    count = 0;
                }
            }
            sendSyncOffer(node.getNodeId(), bsm);
        } catch (InterruptedException e) {
            // This can't really happen
            throw new RuntimeException(e);
        } finally {
            entries.close();
        }
    }
}
 
开发者ID:nsg-ethz,项目名称:iTAP-controller,代码行数:56,代码来源:SyncManager.java

示例3: antientropy

import org.sdnplatform.sync.internal.rpc.TProtocolUtil; //导入方法依赖的package包/类
/**
 * Perform a synchronization with the node specified
 */
public void antientropy(Node node) {
    if (!rpcService.isConnected(node.getNodeId())) return;

    logger.info("[{}->{}] Synchronizing local state to remote node",
                getLocalNodeId(), node.getNodeId());

    for (SynchronizingStorageEngine store : storeRegistry.values()) {
        if (Scope.LOCAL.equals(store.getScope())) {
            if (node.getDomainId() !=
                    getClusterConfig().getNode().getDomainId())
                continue;
        } else if (Scope.UNSYNCHRONIZED.equals(store.getScope())) {
            continue;
        }

        IClosableIterator<Entry<ByteArray,
                              List<Versioned<byte[]>>>> entries =
                store.entries();
        try {
            SyncMessage bsm =
                    TProtocolUtil.getTSyncOfferMessage(store.getName(),
                                                       store.getScope(),
                                                       store.isPersistent());
            int count = 0;
            while (entries.hasNext()) {
                if (!rpcService.isConnected(node.getNodeId())) return;

                Entry<ByteArray, List<Versioned<byte[]>>> pair =
                        entries.next();
                KeyedVersions kv =
                        TProtocolUtil.getTKeyedVersions(pair.getKey(),
                                                        pair.getValue());
                bsm.getSyncOffer().addToVersions(kv);
                count += 1;
                if (count >= 50) {
                    sendSyncOffer(node.getNodeId(), bsm);
                    bsm.getSyncOffer().unsetVersions();
                    count = 0;
                }
            }
            sendSyncOffer(node.getNodeId(), bsm);
        } catch (InterruptedException e) {
            // This can't really happen
            throw new RuntimeException(e);
        } finally {
            entries.close();
        }
    }
}
 
开发者ID:rhoybeen,项目名称:floodlightLB,代码行数:53,代码来源:SyncManager.java


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