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


Java StreamJunction類代碼示例

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


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

示例1: registerForBufferedEvents

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
private void registerForBufferedEvents(Map.Entry<String, StreamJunction> entry) {
    if (entry.getValue().containsBufferedEvents()) {
        String metricName = siddhiAppContext.getSiddhiContext().getStatisticsConfiguration().getMetricPrefix() +
                SiddhiConstants.METRIC_DELIMITER + SiddhiConstants.METRIC_INFIX_SIDDHI_APPS +
                SiddhiConstants.METRIC_DELIMITER + getName() + SiddhiConstants.METRIC_DELIMITER +
                SiddhiConstants.METRIC_INFIX_SIDDHI + SiddhiConstants.METRIC_DELIMITER +
                SiddhiConstants.METRIC_INFIX_STREAMS + SiddhiConstants.METRIC_DELIMITER +
                entry.getKey() + SiddhiConstants.METRIC_DELIMITER + "size";
        boolean matchExist = false;
        for (String regex : siddhiAppContext.getIncludedMetrics()) {
            if (metricName.matches(regex)) {
                matchExist = true;
                break;
            }
        }
        if (matchExist) {
            bufferedEventsTracker.registerEventBufferHolder(entry.getValue(), metricName);
        }
    }
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:21,代碼來源:SiddhiAppRuntime.java

示例2: addStreamJunction

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
/**
 * create local streamJunctions through which events received by partitionStreamReceiver, are sent to
 * queryStreamReceivers
 *
 * @param key              partitioning key
 * @param queryRuntimeList queryRuntime list of the partition
 */
public void addStreamJunction(String key, List<QueryRuntime> queryRuntimeList) {
    StreamJunction streamJunction = cachedStreamJunctionMap.get(streamId + key);
    if (streamJunction == null) {
        streamJunction = partitionRuntime.getLocalStreamJunctionMap().get(streamId + key);
        if (streamJunction == null) {
            streamJunction = createStreamJunction();
            partitionRuntime.addStreamJunction(streamId + key, streamJunction);
        }
        cachedStreamJunctionMap.put(streamId + key, streamJunction);
    }
    for (QueryRuntime queryRuntime : queryRuntimeList) {
        StreamRuntime streamRuntime = queryRuntime.getStreamRuntime();
        for (int i = 0; i < queryRuntime.getInputStreamId().size(); i++) {
            if ((streamRuntime.getSingleStreamRuntimes().get(i)).getProcessStreamReceiver().getStreamId().equals
                    (streamId + key)) {
                streamJunction.subscribe((streamRuntime.getSingleStreamRuntimes().get(i))
                                                 .getProcessStreamReceiver());
            }
        }
    }
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:29,代碼來源:PartitionStreamReceiver.java

示例3: PartitionRuntime

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public PartitionRuntime(ConcurrentMap<String, AbstractDefinition> streamDefinitionMap, ConcurrentMap<String,
        StreamJunction> streamJunctionMap, Partition partition, SiddhiAppContext siddhiAppContext) {
    this.siddhiAppContext = siddhiAppContext;
    if (partition.getPartitionTypeMap().isEmpty()) {
        throw new SiddhiAppCreationException("Partition must have at least one executor. But found none.");
    }
    try {
        Element element = AnnotationHelper.getAnnotationElement("info", "name",
                partition.getAnnotations());
        if (element != null) {
            this.partitionId = element.getValue();
        }
    } catch (DuplicateAnnotationException e) {
        throw new DuplicateAnnotationException(e.getMessageWithOutContext() + " for the same Query " +
                partition.toString(), e, e.getQueryContextStartIndex(), e.getQueryContextEndIndex(),
                siddhiAppContext.getName(), siddhiAppContext.getSiddhiAppString());
    }
    if (partitionId == null) {
        this.partitionId = UUID.randomUUID().toString();
    }
    elementId = "PartitionRuntime-" + siddhiAppContext.getElementIdGenerator().createNewId();
    this.partition = partition;
    this.streamDefinitionMap = streamDefinitionMap;
    this.streamJunctionMap = streamJunctionMap;
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:26,代碼來源:PartitionRuntime.java

示例4: addEventTrigger

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public static void addEventTrigger(TriggerDefinition triggerDefinition,
                                   ConcurrentMap<String, Trigger> eventTriggerMap,
                                   ConcurrentMap<String, StreamJunction> streamJunctionMap,
                                   SiddhiAppContext siddhiAppContext) {
    if (!eventTriggerMap.containsKey(triggerDefinition.getId())) {
        Trigger trigger;
        if (triggerDefinition.getAtEvery() != null) {
            trigger = new PeriodicTrigger();
        } else if (triggerDefinition.getAt().trim().equalsIgnoreCase(SiddhiConstants.TRIGGER_START)) {
            trigger = new StartTrigger();
        } else {
            trigger = new CronTrigger();
        }
        StreamJunction streamJunction = streamJunctionMap.get(triggerDefinition.getId());
        trigger.init(triggerDefinition, siddhiAppContext, streamJunction);
        siddhiAppContext.addEternalReferencedHolder(trigger);
        eventTriggerMap.putIfAbsent(trigger.getId(), trigger);
    }
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:20,代碼來源:DefinitionParserHelper.java

示例5: ObjectSizeCalculator

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
/**
 * Creates an object size calculator that can calculate object sizes for a given
 * {@code memoryLayoutSpecification}.
 *
 * @param memoryLayoutSpecification a description of the JVM memory layout.
 */
public ObjectSizeCalculator(MemoryLayoutSpecification memoryLayoutSpecification) {
    Preconditions.checkNotNull(memoryLayoutSpecification);
    arrayHeaderSize = memoryLayoutSpecification.getArrayHeaderSize();
    objectHeaderSize = memoryLayoutSpecification.getObjectHeaderSize();
    objectPadding = memoryLayoutSpecification.getObjectPadding();
    referenceSize = memoryLayoutSpecification.getReferenceSize();
    superclassFieldPadding = memoryLayoutSpecification.getSuperclassFieldPadding();
    ignoreCalculation.add(SiddhiAppContext.class);
    ignoreCalculation.add(StreamJunction.class);
    ignoreCalculation.add(OutputCallback.class);
    ignoreCalculation.add(StreamCallback.class);
    ignoreCalculation.add(ThroughputTracker.class);
    ignoreCalculation.add(LatencyTracker.class);
    ignoreCalculation.add(MemoryUsageTracker.class);
    ignoreCalculation.add(BufferedEventsTracker.class);
    ignoreCalculation.add(StatisticsManager.class);
    ignoreCalculation.add(MemoryCalculable.class);
    ignoreCalculation.add(AbstractRecordTable.class);
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:26,代碼來源:ObjectSizeCalculator.java

示例6: clone

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public QueryRuntime clone(String key, ConcurrentMap<String, StreamJunction> localStreamJunctionMap) {

        StreamRuntime clonedStreamRuntime = this.streamRuntime.clone(key);
        QuerySelector clonedSelector = this.selector.clone(key);
        OutputRateLimiter clonedOutputRateLimiter = outputRateLimiter.clone(key);

        QueryRuntime queryRuntime = new QueryRuntime(query,siddhiContext,clonedStreamRuntime,clonedSelector,clonedOutputRateLimiter,this.metaStateEvent);
        queryRuntime.queryId = this.queryId + key;
        queryRuntime.setToLocalStream(toLocalStream);
        queryRuntime.setDefinitionMap(definitionMap);

        if (!toLocalStream) {
            queryRuntime.outputRateLimiter.setOutputCallback(outputCallback);
            queryRuntime.outputCallback = this.outputCallback;
        } else {
            OutputCallback clonedQueryOutputCallback = OutputParser.constructOutputCallback(query.getOutputStream(), key, localStreamJunctionMap, outputStreamDefinition, siddhiContext);
            queryRuntime.outputRateLimiter.setOutputCallback(clonedQueryOutputCallback);
            queryRuntime.outputCallback = clonedQueryOutputCallback;
        }
        return queryRuntime;

    }
 
開發者ID:sacjaya,項目名稱:siddhi-3,代碼行數:23,代碼來源:QueryRuntime.java

示例7: PartitionRuntime

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public PartitionRuntime(ExecutionPlanRuntime executionPlanRuntime, Partition partition, ConcurrentMap<String, AbstractDefinition> streamDefinitionMap, ConcurrentMap<String, StreamJunction> streamJunctionMap, ConcurrentMap<String, InputHandler> inputHandlerMap, SiddhiContext siddhiContext) {

        try {
            Element element = AnnotationHelper.getAnnotationElement("info", "name", partition.getAnnotations());
            if (element != null) {
                this.partitionId = element.getValue();
            }
        } catch (DuplicateAnnotationException e) {
            throw new QueryCreationException(e.getMessage() + " for the same Query " + partition.toString());
        }
        if (partitionId == null) {
            this.partitionId = UUID.randomUUID().toString();
        }
        this.streamDefinitionMap = streamDefinitionMap;
        this.streamJunctionMap = streamJunctionMap;
        this.inputHandlerMap = inputHandlerMap;
        this.partition = partition;
        this.executionPlanRuntime = executionPlanRuntime;
        this.siddhiContext = siddhiContext;
        for (Query query : partition.getQueryList()) {
            addQuery(query);
        }
    }
 
開發者ID:sacjaya,項目名稱:siddhi-3,代碼行數:24,代碼來源:PartitionRuntime.java

示例8: removePartition

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public void removePartition(ConcurrentMap<String,StreamJunction> streamJunctionMap, ConcurrentMap<String,AbstractDefinition> streamDefinitionMap) {

        for(PartitionInstanceRuntime partitionInstanceRuntime :partitionInstanceRuntimeMap.values()){
            partitionInstanceRuntime.remove(streamJunctionMap,streamDefinitionMap);
        }

        for(String streamId:localStreamJunctionMap.keySet()){
            localStreamJunctionMap.get(streamId).removeEventFlows();
        }
        localStreamDefinitionMap.clear();
        localStreamJunctionMap.clear();


        for (HandlerProcessor queryStreamProcessor : handlerProcessors) {
            StreamJunction junction = streamJunctionMap.get(queryStreamProcessor.getStreamId());
            if (junction != null) {
                junction.removeEventFlow(queryStreamProcessor);
            }
        }
    }
 
開發者ID:sacjaya,項目名稱:siddhi-3,代碼行數:21,代碼來源:PartitionRuntime.java

示例9: removeQuery

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public void removeQuery(ConcurrentMap<String, StreamJunction> streamJunctionMap,
                        ConcurrentMap<String, AbstractDefinition> streamTableDefinitionMap) {
    for (HandlerProcessor queryStreamProcessor : handlerProcessors) {
        StreamJunction junction = streamJunctionMap.get(queryStreamProcessor.getStreamId());
        if (junction != null) {
            junction.removeEventFlow(queryStreamProcessor);
        }
    }
    streamTableDefinitionMap.remove(query.getOutputStream().getStreamId());
}
 
開發者ID:redBorder,項目名稱:rb-bi,代碼行數:11,代碼來源:QueryManager.java

示例10: constructQueryCreator

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public static QueryCreator constructQueryCreator(String queryId, Query query, ConcurrentMap<String, AbstractDefinition> streamTableDefinitionMap, ConcurrentMap<String, StreamJunction> streamJunctionMap,
                                                 ConcurrentMap<String, EventTable> eventTableMap, OutputRateManager outputRateManager,
                                                 SiddhiContext siddhiContext) {
    if (query.getInputStream() instanceof SingleStream) {
        return new BasicQueryCreator(queryId, query, streamTableDefinitionMap, eventTableMap, outputRateManager, siddhiContext);
    } else if (query.getInputStream() instanceof JoinStream) {
        return new JoinQueryCreator(queryId, query, streamTableDefinitionMap, eventTableMap, outputRateManager, siddhiContext);
    } else if (query.getInputStream() instanceof PatternStream) {
        return new PatternQueryCreator(queryId, query, streamTableDefinitionMap, eventTableMap, outputRateManager, siddhiContext);
    } else if (query.getInputStream() instanceof SequenceStream) {
        return new SequenceQueryCreator(queryId, query, streamTableDefinitionMap, eventTableMap, outputRateManager, siddhiContext);
    } else {
        throw new QueryCreationException("Unsupported input stream found, " + query.getInputStream().getClass().getName());
    }
}
 
開發者ID:redBorder,項目名稱:rb-bi,代碼行數:16,代碼來源:QueryCreatorFactiory.java

示例11: InputManager

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public InputManager(SiddhiAppContext siddhiAppContext,
                    ConcurrentMap<String, AbstractDefinition> streamDefinitionMap,
                    ConcurrentMap<String, StreamJunction> streamJunctionMap) {
    this.streamJunctionMap = streamJunctionMap;
    this.inputDistributor = new InputDistributor();
    this.inputEntryValve = new InputEntryValve(siddhiAppContext, inputDistributor);
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:8,代碼來源:InputManager.java

示例12: constructInputHandler

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public InputHandler constructInputHandler(String streamId) {
    InputHandler inputHandler = new InputHandler(streamId, inputHandlerMap.size(), inputEntryValve);
    StreamJunction streamJunction = streamJunctionMap.get(streamId);
    if (streamJunction == null) {
        throw new DefinitionNotExistException("Stream with stream ID " + streamId + " has not been defined");
    }
    inputDistributor.addInputProcessor(streamJunctionMap.get(streamId).constructPublisher());
    inputHandlerMap.put(streamId, inputHandler);
    return inputHandler;
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:11,代碼來源:InputManager.java

示例13: addCallback

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public void addCallback(String streamId, StreamCallback streamCallback) {
    streamCallback.setStreamId(streamId);
    StreamJunction streamJunction = streamJunctionMap.get(streamId);
    if (streamJunction == null) {
        throw new DefinitionNotExistException("No stream found with name: " + streamId);
    }
    streamCallback.setStreamDefinition(streamDefinitionMap.get(streamId));
    streamCallback.setContext(siddhiAppContext);
    streamJunction.subscribe(streamCallback);
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:11,代碼來源:SiddhiAppRuntime.java

示例14: clone

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public QueryRuntime clone(String key, ConcurrentMap<String, StreamJunction> localStreamJunctionMap) {

        LockWrapper lockWrapper = null;
        if (synchronised) {
            lockWrapper = new LockWrapper("");
            lockWrapper.setLock(new ReentrantLock());
        }
        StreamRuntime clonedStreamRuntime = this.streamRuntime.clone(key);
        QuerySelector clonedSelector = this.selector.clone(key);
        OutputRateLimiter clonedOutputRateLimiter = outputRateLimiter.clone(key);
        clonedOutputRateLimiter.init(siddhiAppContext, lockWrapper, queryId);

        QueryRuntime queryRuntime = new QueryRuntime(query, siddhiAppContext, clonedStreamRuntime, clonedSelector,
                clonedOutputRateLimiter, outputCallback, this.metaComplexEvent,
                synchronised, this.queryId + key);
        QueryParserHelper.initStreamRuntime(clonedStreamRuntime, metaComplexEvent, lockWrapper, queryId);

        queryRuntime.setToLocalStream(toLocalStream);

        if (!toLocalStream) {
            queryRuntime.outputRateLimiter.setOutputCallback(outputCallback);
            queryRuntime.outputCallback = this.outputCallback;
        } else {
            OutputCallback clonedQueryOutputCallback = OutputParser.constructOutputCallback(query.getOutputStream(),
                    key,
                    localStreamJunctionMap,
                    outputStreamDefinition,
                    siddhiAppContext,
                    queryId);
            queryRuntime.outputRateLimiter.setOutputCallback(clonedQueryOutputCallback);
            queryRuntime.outputCallback = clonedQueryOutputCallback;
        }
        return queryRuntime;

    }
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:36,代碼來源:QueryRuntime.java

示例15: addStreamJunction

import org.wso2.siddhi.core.stream.StreamJunction; //導入依賴的package包/類
public static void addStreamJunction(StreamDefinition streamDefinition,
                                     ConcurrentMap<String, StreamJunction> streamJunctionMap,
                                     SiddhiAppContext siddhiAppContext) {
    if (!streamJunctionMap.containsKey(streamDefinition.getId())) {
        StreamJunction streamJunction = new StreamJunction(streamDefinition,
                siddhiAppContext.getExecutorService(),
                siddhiAppContext.getBufferSize(), siddhiAppContext);
        streamJunctionMap.putIfAbsent(streamDefinition.getId(), streamJunction);
    }
}
 
開發者ID:wso2,項目名稱:siddhi,代碼行數:11,代碼來源:DefinitionParserHelper.java


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