All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.axonframework.springboot.TracingProperties Maven / Gradle / Ivy

/*
 * Copyright (c) 2010-2023. Axon Framework
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.axonframework.springboot;

import org.axonframework.commandhandling.CommandBus;
import org.springframework.boot.context.properties.ConfigurationProperties;

import java.time.Duration;

/**
 * Properties describing the settings for tracing.
 *
 * @author Mitchell Herrijgers
 * @since 4.6.0
 */
@ConfigurationProperties("axon.tracing")
public class TracingProperties {
    /**
     * Properties describing the tracing settings for the {@link org.axonframework.eventsourcing.Snapshotter}.
     */
    private SnapshotterProperties snapshotter = new SnapshotterProperties();

    /**
     * Properties describing the tracing settings for the {@link CommandBus}.
     */
    private CommandBusProperties commandBus = new CommandBusProperties();

    /**
     * Properties describing the tracing settings for the {@link org.axonframework.queryhandling.QueryBus}.
     */
    private QueryBusProperties queryBus = new QueryBusProperties();

    /**
     * Properties describing the tracing settings for the {@link org.axonframework.deadline.DeadlineManager}.
     */
    private DeadlineManagerProperties deadlineManager = new DeadlineManagerProperties();

    /**
     * Properties describing the tracing settings for the {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     */
    private SagaManagerProperties sagaManager = new SagaManagerProperties();

    /**
     * Properties describing the tracing settings for the {@link org.axonframework.modelling.command.Repository}.
     */
    private RepositoryProperties repository = new RepositoryProperties();

    /**
     * Properties describing the tracing settings for the {@link org.axonframework.eventhandling.EventProcessor}.
     */
    private EventProcessorProperties eventProcessor = new EventProcessorProperties();

    /**
     * Whether to show event sourcing handlers in traces. This can be very noisy, especially when larger aggregates are
     * loaded without a snapshot in place. Use with care.
     */
    private boolean showEventSourcingHandlers = false;

    /**
     * Defines which {@link org.axonframework.tracing.SpanAttributesProvider SpanAttributesProviders}, provided by
     * default by Axon Framework, are active.
     */
    private AttributeProviders attributeProviders;

    /**
     * Returns the properties describing the tracing settings for the {@link org.axonframework.eventsourcing.Snapshotter}.
     *
     * @return the properties describing the tracing settings for the {@link org.axonframework.eventsourcing.Snapshotter}.
     */
    public SnapshotterProperties getSnapshotter() {
        return snapshotter;
    }

    /**
     * Sets the properties describing the tracing settings for the {@link org.axonframework.eventsourcing.Snapshotter}.
     *
     * @param snapshotter the properties describing the tracing settings for the {@link org.axonframework.eventsourcing.Snapshotter}.
     */
    public void setSnapshotter(SnapshotterProperties snapshotter) {
        this.snapshotter = snapshotter;
    }

    /**
     * Returns the properties describing the tracing settings for the {@link CommandBus}.
     *
     * @return The properties describing the tracing settings for the {@link CommandBus}.
     */
    public CommandBusProperties getCommandBus() {
        return commandBus;
    }

    /**
     * Sets the properties describing the tracing settings for the {@link CommandBus}.
     *
     * @param commandBus The properties describing the tracing settings for the {@link CommandBus}.
     */
    public void setCommandBus(CommandBusProperties commandBus) {
        this.commandBus = commandBus;
    }

    /**
     * Returns the properties describing the tracing settings for the {@link org.axonframework.queryhandling.QueryBus}.
     * @return the properties describing the tracing settings for the {@link org.axonframework.queryhandling.QueryBus}.
     */
    public QueryBusProperties getQueryBus() {
        return queryBus;
    }

    /**
     * Sets the properties describing the tracing settings for the {@link org.axonframework.queryhandling.QueryBus}.
     * @param queryBus the properties describing the tracing settings for the {@link org.axonframework.queryhandling.QueryBus}.
     */
    public void setQueryBus(QueryBusProperties queryBus) {
        this.queryBus = queryBus;
    }

    /**
     * Returns the properties describing the tracing settings for the
     * {@link org.axonframework.deadline.DeadlineManager}.
     *
     * @return the properties describing the tracing settings for the
     * {@link org.axonframework.deadline.DeadlineManager}.
     */
    public DeadlineManagerProperties getDeadlineManager() {
        return deadlineManager;
    }

    /**
     * Sets the properties describing the tracing settings for the {@link org.axonframework.deadline.DeadlineManager}.
     *
     * @param deadlineManager the properties describing the tracing settings for the
     *                        {@link org.axonframework.deadline.DeadlineManager}.
     */
    public void setDeadlineManager(DeadlineManagerProperties deadlineManager) {
        this.deadlineManager = deadlineManager;
    }

    /**
     * Returns the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     *
     * @return the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     */
    public SagaManagerProperties getSagaManager() {
        return sagaManager;
    }

    /**
     * Sets the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     *
     * @param sagaManager the properties describing the tracing settings for the
     *                    {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     */
    public void setSagaManager(SagaManagerProperties sagaManager) {
        this.sagaManager = sagaManager;
    }

    /**
     * Returns the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.command.Repository}.
     *
     * @return the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.command.Repository}.
     */
    public RepositoryProperties getRepository() {
        return repository;
    }

    /**
     * Sets the properties describing the tracing settings for the
     * {@link org.axonframework.modelling.command.Repository}.
     *
     * @param repository the properties describing the tracing settings for the
     *                   {@link org.axonframework.modelling.command.Repository}.
     */
    public void setRepository(RepositoryProperties repository) {
        this.repository = repository;
    }

    /**
     * Returns the properties describing the tracing settings for the
     * {@link org.axonframework.eventhandling.EventProcessor}.
     *
     * @return The properties describing the tracing settings for the
     * {@link org.axonframework.eventhandling.EventProcessor}.
     */
    public EventProcessorProperties getEventProcessor() {
        return eventProcessor;
    }

    /**
     * Sets the properties describing the tracing settings for the
     * {@link org.axonframework.eventhandling.EventProcessor}.
     *
     * @param eventProcessor The properties describing the tracing settings for the
     *                       {@link org.axonframework.eventhandling.EventProcessor}.
     */
    public void setEventProcessor(EventProcessorProperties eventProcessor) {
        this.eventProcessor = eventProcessor;
    }

    /**
     * Getting value for showing event sourcing handlers in traces.
     *
     * @return Whether event sourcing handlers should show up on traces.
     */
    public boolean isShowEventSourcingHandlers() {
        return showEventSourcingHandlers;
    }

    /**
     * Setting value for showing event sourcing handlers in traces.
     *
     * @param showEventSourcingHandlers The new value for showing event sourcing handlers.
     */
    public void setShowEventSourcingHandlers(boolean showEventSourcingHandlers) {
        this.showEventSourcingHandlers = showEventSourcingHandlers;
    }

    /**
     * Getting value for nesting handlers in dispatching traces.
     *
     * @return Whether handlers should be nested in dispatching traces
     * @deprecated Use {@link EventProcessorProperties#isDistributedInSameTrace()} instead.
     */
    @Deprecated
    public boolean isNestedHandlers() {
        return eventProcessor.isDistributedInSameTrace();
    }

    /**
     * Setting value for nesting handlers in dispatching traces.
     *
     * @param nestedHandlers The new value for nesting handlers in dispatching trace.
     * @deprecated Use {@link EventProcessorProperties#setDisableBatchTrace(boolean)} instead.
     */
    @Deprecated
    public void setNestedHandlers(boolean nestedHandlers) {
        eventProcessor.setDistributedInSameTrace(nestedHandlers);
    }

    /**
     * The time limit set on nested handlers inside dispatching trace. Only affects events and deadlines, other messages
     * are always nested.
     *
     * @return For how long event messages should be nested in their dispatching trace.
     * @deprecated Use {@link EventProcessorProperties#getDistributedInSameTraceTimeLimit()} instead.
     */
    @Deprecated
    public Duration getNestedTimeLimit() {
        return eventProcessor.getDistributedInSameTraceTimeLimit();
    }

    /**
     * Sets the value for the time limit set on nested handlers inside dispatching trace. Only affects events. Commands
     * and queries are always nested.
     * @deprecated Use {@link EventProcessorProperties#setDistributedInSameTraceTimeLimit(Duration)} instead.
     */
    @Deprecated
    public void setNestedTimeLimit(Duration nestedTimeLimit) {
        eventProcessor.setDistributedInSameTraceTimeLimit(nestedTimeLimit);
    }

    /**
     * The value for which {@link org.axonframework.tracing.SpanAttributesProvider}s are enabled.
     *
     * @return The {@link AttributeProviders} value.
     */
    public AttributeProviders getAttributeProviders() {
        return attributeProviders;
    }

    /**
     * Sets the value for which {@link org.axonframework.tracing.SpanAttributesProvider SpanAttributesProviders} are
     * enabled.
     *
     * @param attributeProviders The new list of
     *                           {@link org.axonframework.tracing.SpanAttributesProvider SpanAttributesProviders}.
     */
    public void setAttributeProviders(AttributeProviders attributeProviders) {
        this.attributeProviders = attributeProviders;
    }

    /**
     * Defines which {@link org.axonframework.tracing.SpanAttributesProvider}s are enabled. By default they are all
     * enabled.
     */
    public static class AttributeProviders {

        /**
         * Enables the {@link org.axonframework.tracing.attributes.AggregateIdentifierSpanAttributesProvider}.
         */
        private boolean aggregateIdentifier = true;
        /**
         * Enables the {@link org.axonframework.tracing.attributes.MessageIdSpanAttributesProvider}.
         */
        private boolean messageId = true;
        /**
         * Enables the {@link org.axonframework.tracing.attributes.MessageNameSpanAttributesProvider}.
         */
        private boolean messageName = true;
        /**
         * Enables the {@link org.axonframework.tracing.attributes.MessageTypeSpanAttributesProvider}.
         */
        private boolean messageType = true;
        /**
         * Enables the {@link org.axonframework.tracing.attributes.MetadataSpanAttributesProvider}.
         */
        private boolean metadata = true;
        /**
         * Enables the {@link org.axonframework.tracing.attributes.PayloadTypeSpanAttributesProvider}.
         */
        private boolean payloadType = true;

        /**
         * Whether the {@link org.axonframework.tracing.attributes.AggregateIdentifierSpanAttributesProvider} is
         * enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isAggregateIdentifier() {
            return aggregateIdentifier;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.AggregateIdentifierSpanAttributesProvider} is
         * enabled.
         *
         * @param aggregateIdentifier Whether the provider is enabled.
         */
        public void setAggregateIdentifier(boolean aggregateIdentifier) {
            this.aggregateIdentifier = aggregateIdentifier;
        }

        /**
         * Whether the {@link org.axonframework.tracing.attributes.MessageIdSpanAttributesProvider} is enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isMessageId() {
            return messageId;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.MessageIdSpanAttributesProvider} is enabled.
         *
         * @param messageId Whether the provider is enabled.
         */
        public void setMessageId(boolean messageId) {
            this.messageId = messageId;
        }

        /**
         * Whether the {@link org.axonframework.tracing.attributes.MessageNameSpanAttributesProvider} is enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isMessageName() {
            return messageName;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.MessageNameSpanAttributesProvider} is enabled.
         *
         * @param messageName Whether the provider is enabled.
         */
        public void setMessageName(boolean messageName) {
            this.messageName = messageName;
        }

        /**
         * Whether the {@link org.axonframework.tracing.attributes.MessageTypeSpanAttributesProvider} is enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isMessageType() {
            return messageType;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.MessageTypeSpanAttributesProvider} is enabled.
         *
         * @param messageType Whether the provider is enabled.
         */
        public void setMessageType(boolean messageType) {
            this.messageType = messageType;
        }

        /**
         * Whether the {@link org.axonframework.tracing.attributes.MetadataSpanAttributesProvider} is enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isMetadata() {
            return metadata;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.MetadataSpanAttributesProvider} is enabled.
         *
         * @param metadata Whether the provider is enabled.
         */
        public void setMetadata(boolean metadata) {
            this.metadata = metadata;
        }

        /**
         * Whether the {@link org.axonframework.tracing.attributes.PayloadTypeSpanAttributesProvider} is enabled.
         *
         * @return Whether the attribute provider is enabled.
         */
        public boolean isPayloadType() {
            return payloadType;
        }

        /**
         * Sets whether the {@link org.axonframework.tracing.attributes.PayloadTypeSpanAttributesProvider} is enabled.
         *
         * @param payloadType Whether the provider is enabled.
         */
        public void setPayloadType(boolean payloadType) {
            this.payloadType = payloadType;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the {@link org.axonframework.eventsourcing.Snapshotter}.
     */
    public static class SnapshotterProperties {
        /**
         * Whether the creation of the snapshot should be represented by a separate trace.
         */
        private boolean separateTrace = false;

        /**
         * Wether the aggregate type should be included in the span names of the {@link org.axonframework.eventsourcing.Snapshotter} spans.
         */
        private boolean aggregateTypeInSpanName = true;

        /**
         * Whether the creation of the snapshot should be represented by a separate trace.
         *
         * @return whether the creation of the snapshot should be represented by a separate trace.
         */
        public boolean isSeparateTrace() {
            return separateTrace;
        }

        /**
         * Sets whether the creation of the snapshot should be represented by a separate trace.
         *
         * @param separateTrace whether the creation of the snapshot should be represented by a separate trace.
         */
        public void setSeparateTrace(boolean separateTrace) {
            this.separateTrace = separateTrace;
        }

        /**
         * Whether the aggregate type should be included in the span names of the {@link org.axonframework.eventsourcing.Snapshotter} spans.
         *
         * @return whether the aggregate type should be included in the span names of the {@link org.axonframework.eventsourcing.Snapshotter} spans.
         */
        public boolean isAggregateTypeInSpanName() {
            return aggregateTypeInSpanName;
        }

        /**
         * Sets whether the aggregate type should be included in the span names of the {@link org.axonframework.eventsourcing.Snapshotter} spans.
         *
         * @param aggregateTypeInSpanName whether the aggregate type should be included in the span names of the {@link org.axonframework.eventsourcing.Snapshotter} spans.
         */
        public void setAggregateTypeInSpanName(boolean aggregateTypeInSpanName) {
            this.aggregateTypeInSpanName = aggregateTypeInSpanName;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.commandhandling.CommandBus}.
     *
     * @since 4.9.0
     */
    public static class CommandBusProperties {

        /**
         * Whether distributed commands should be part of the same trace.
         */
        private boolean distributedInSameTrace = true;

        /**
         * Whether distributed commands should be part of the same trace. Defaults to {@code true}.
         *
         * @return whether distributed commands should be part of the same trace.
         */
        public boolean isDistributedInSameTrace() {
            return distributedInSameTrace;
        }

        /**
         * Sets whether distributed commands should be part of the same trace.
         *
         * @param distributedInSameTrace whether distributed commands should be part of the same trace.
         */
        public void setDistributedInSameTrace(boolean distributedInSameTrace) {
            this.distributedInSameTrace = distributedInSameTrace;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.queryhandling.QueryBus}.
     *
     * @since 4.9.0
     */
    public static class QueryBusProperties {

        /**
         * Whether distributed queries should be part of the same trace.
         */
        private boolean distributedInSameTrace = true;
        
        /**
         * Whether distributed queries should be part of the same trace. Defaults to {@code true}.
         *
         * @return whether distributed queries should be part of the same trace.
         */
        public boolean isDistributedInSameTrace() {
            return distributedInSameTrace;
        }

        /**
         * Sets whether distributed queries should be part of the same trace.
         *
         * @param distributedInSameTrace whether distributed queries should be part of the same trace.
         */
        public void setDistributedInSameTrace(boolean distributedInSameTrace) {
            this.distributedInSameTrace = distributedInSameTrace;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.deadline.DeadlineManager}.
     *
     * @since 4.9.0
     */
    public static class DeadlineManagerProperties {

        /**
         * The name of the attribute used to store the deadline id in the span. Defaults to {@code axon.deadlineId}.
         */
        private String deadlineIdAttributeName = "axon.deadlineId";
        /**
         * The name of the attribute used to store the deadline scope in the span.
         */
        private String deadlineScopeAttributeName = "axon.scope";

        /**
         * The name of the attribute used to store the deadline id in the span. Defaults to {@code axon.deadlineId}.
         *
         * @return The name of the attribute used to store the deadline id in the span.
         */
        public String getDeadlineIdAttributeName() {
            return deadlineIdAttributeName;
        }

        /**
         * The name of the attribute used to store the deadline id in the span. Defaults to {@code axon.deadlineId}.
         *
         * @param deadlineIdAttributeName The name of the attribute used to store the deadline id in the span.
         */
        public void setDeadlineIdAttributeName(String deadlineIdAttributeName) {
            this.deadlineIdAttributeName = deadlineIdAttributeName;
        }

        /**
         * The name of the attribute used to store the deadline scope in the span. Defaults to {@code axon.scope}.
         *
         * @return The name of the attribute used to store the deadline scope in the span.
         */
        public String getDeadlineScopeAttributeName() {
            return deadlineScopeAttributeName;
        }

        /**
         * The name of the attribute used to store the deadline scope in the span. Defaults to {@code axon.scope}.
         *
         * @param deadlineScopeAttributeName The name of the attribute used to store the deadline scope in the span.
         */
        public void setDeadlineScopeAttributeName(String deadlineScopeAttributeName) {
            this.deadlineScopeAttributeName = deadlineScopeAttributeName;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.modelling.command.Repository}.
     *
     * @since 4.9.0
     */
    public static class RepositoryProperties {

        /**
         * The name of the attribute used to store the aggregate id in the span. Defaults to {@code axon.aggregateId}.
         */
        private String aggregateIdAttributeName = "axon.deadlineId";

        /**
         * The name of the attribute used to store the aggregate id in the span. Defaults to {@code axon.aggregateId}.
         *
         * @return The name of the attribute used to store the aggregate id in the span.
         */
        public String getAggregateIdAttributeName() {
            return aggregateIdAttributeName;
        }

        /**
         * The name of the attribute used to store the aggregate id in the span. Defaults to {@code axon.aggregateId}.
         *
         * @param aggregateIdAttributeName The name of the attribute used to store the aggregate id in the span.
         */
        public void setAggregateIdAttributeName(String aggregateIdAttributeName) {
            this.aggregateIdAttributeName = aggregateIdAttributeName;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.modelling.saga.AbstractSagaManager}.
     *
     * @since 4.9.0
     */
    public static class SagaManagerProperties {

        /**
         * The name of the attribute used to store the saga id in the span. Defaults to {@code axon.sagaIdentifier}.
         */
        private String sagaIdentifierAttributeName = "axon.sagaIdentifier";

        /**
         * The name of the attribute used to store the saga id in the span. Defaults to {@code axon.sagaIdentifier}.
         *
         * @return The name of the attribute used to store the saga id in the span.
         */
        public String getSagaIdentifierAttributeName() {
            return sagaIdentifierAttributeName;
        }

        /**
         * The name of the attribute used to store the saga id in the span. Defaults to {@code axon.sagaIdentifier}.
         *
         * @param sagaIdentifierAttributeName The name of the attribute used to store the saga id in the span.
         */
        public void setSagaIdentifierAttributeName(String sagaIdentifierAttributeName) {
            this.sagaIdentifierAttributeName = sagaIdentifierAttributeName;
        }
    }

    /**
     * Configuration properties for the behavior of creating tracing spans for the
     * {@link org.axonframework.eventhandling.EventProcessor} implementations.
     *
     * @since 4.9.0
     */
    public static class EventProcessorProperties {

        /**
         * Disables the creation of a batch trace. This means each event is handled in its own trace.
         * Defaults to {@code false}.
         */
        private boolean disableBatchTrace = false;

        /**
         * Whether distributed events should be part of the same trace. Defaults to {@code false}. When set to
         * {@code true}, the {@link org.axonframework.eventhandling.EventProcessor} will create a new trace each batch
         * event, as long as the batch is handled within the time limit set by
         * {@link #distributedInSameTraceTimeLimit}.
         */
        private boolean distributedInSameTrace = false;

        /**
         * The time limit for events handled by a {@link org.axonframework.eventhandling.StreamingEventProcessor} to be
         * traced in the same trace as the trace that published it. Defaults to 2 minutes. Only used when
         * {@link #distributedInSameTrace} is {@code true}.
         */
        private Duration distributedInSameTraceTimeLimit = Duration.ofMinutes(2);

        /**
         * Disables the creation of a batch trace. This means each event is handled in its own trace.
         *
         * @return whether batch tracing is disabled.
         */
        public boolean isDisableBatchTrace() {
            return disableBatchTrace;
        }

        /**
         * Disables the creation of a batch trace. This means each event is handled in its own trace.
         *
         * @param disableBatchTrace Whether batch tracing is disabled.
         */
        public void setDisableBatchTrace(boolean disableBatchTrace) {
            this.disableBatchTrace = disableBatchTrace;
        }


        /**
         * Whether distributed events should be part of the same trace. Defaults to {@code false}. When set to
         * {@code true}, the {@link org.axonframework.eventhandling.EventProcessor} will create a new trace each batch
         * event, as long as the batch is handled within the time limit set by
         * {@link #distributedInSameTraceTimeLimit}.
         *
         * @return Whether distributed events should be part of the same trace.
         */
        public boolean isDistributedInSameTrace() {
            return distributedInSameTrace;
        }

        /**
         * Whether distributed events should be part of the same trace. Defaults to {@code false}. When set to
         * {@code true}, the {@link org.axonframework.eventhandling.EventProcessor} will create a new trace each batch
         * event, as long as the batch is handled within the time limit set by
         * {@link #distributedInSameTraceTimeLimit}.
         *
         * @param distributedInSameTrace Whether distributed events should be part of the same trace.
         */
        public void setDistributedInSameTrace(boolean distributedInSameTrace) {
            this.distributedInSameTrace = distributedInSameTrace;
        }

        /**
         * The time limit for events handled by a {@link org.axonframework.eventhandling.StreamingEventProcessor} to be
         * traced in the same trace as the trace that published it. Defaults to 2 minutes. Only used when
         * {@link #distributedInSameTrace} is {@code true}.
         *
         * @return The time limit for events handled by a
         * {@link org.axonframework.eventhandling.StreamingEventProcessor} to be traced in the same trace as the trace
         * that published it.
         */
        public Duration getDistributedInSameTraceTimeLimit() {
            return distributedInSameTraceTimeLimit;
        }

        /**
         * The time limit for events handled by a {@link org.axonframework.eventhandling.StreamingEventProcessor} to be
         * traced in the same trace as the trace that published it. Defaults to 2 minutes. Only used when
         * {@link #distributedInSameTrace} is {@code true}.
         *
         * @param distributedInSameTraceTimeLimit The time limit for events handled by a
         *                                        {@link org.axonframework.eventhandling.StreamingEventProcessor} to be
         *                                        traced in the same trace as the trace that published it.
         */
        public void setDistributedInSameTraceTimeLimit(Duration distributedInSameTraceTimeLimit) {
            this.distributedInSameTraceTimeLimit = distributedInSameTraceTimeLimit;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy