⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 idempotentreceiver.java

📁 提供ESB 应用mule源代码 提供ESB 应用mule源代码
💻 JAVA
字号:
/* * $Id: IdempotentReceiver.java 13054 2008-10-10 21:45:36Z dfeist $ * -------------------------------------------------------------------------------------- * Copyright (c) MuleSource, Inc.  All rights reserved.  http://www.mulesource.com * * The software in this package is published under the terms of the CPAL v1.0 * license, a copy of which has been included with this distribution in the * LICENSE.txt file. */package org.mule.routing.inbound;import org.mule.api.MessagingException;import org.mule.api.MuleEvent;import org.mule.api.lifecycle.InitialisationException;import org.mule.api.routing.RoutingException;import org.mule.api.store.ObjectStore;import org.mule.config.i18n.CoreMessages;import org.mule.util.expression.ExpressionEvaluatorManager;import org.mule.util.store.InMemoryObjectStore;import java.text.MessageFormat;/** * <code>IdempotentReceiver</code> ensures that only unique messages are received by a * service. It does this by checking the unique ID of the incoming message. Note that * the underlying endpoint must support unique message IDs for this to work, otherwise a * <code>UniqueIdNotSupportedException</code> is thrown.<br> * By default this implementation uses an instance of */public class IdempotentReceiver extends SelectiveConsumer{    protected volatile ObjectStore store;    protected volatile String assignedComponentName;    protected String idExpression = MessageFormat.format("{0}message:id{1}",                                                         ExpressionEvaluatorManager.DEFAULT_EXPRESSION_PREFIX,                                                         ExpressionEvaluatorManager.DEFAULT_EXPRESSION_POSTFIX);    public IdempotentReceiver()    {        super();    }    protected void initialize(MuleEvent event) throws RoutingException    {        if (assignedComponentName == null && store == null)        {            this.assignedComponentName = event.getService().getName();            try            {                this.store = this.createMessageIdStore();            }            catch (InitialisationException e)            {                throw new RoutingException(event.getMessage(), event.getEndpoint(), e);            }        }    }    protected ObjectStore createMessageIdStore() throws InitialisationException    {        InMemoryObjectStore s = new InMemoryObjectStore();        s.setName(assignedComponentName);        s.setMaxEntries(-1);        s.setEntryTTL(60 * 5);        s.setExpirationInterval(6000);        s.initialise();        return s;    }    // @Override    public boolean isMatch(MuleEvent event) throws MessagingException    {        if (!super.isMatch(event))        {            return false;        }        else        {            if (store == null)            {                // we need to load this on the first request as we need the service                // name                synchronized (this)                {                    this.initialize(event);                }            }            try            {                return !store.containsObject(this.getIdForEvent(event));            }            catch (Exception ex)            {                throw new RoutingException(event.getMessage(), event.getEndpoint(), ex);            }        }    }    // @Override    public MuleEvent[] process(MuleEvent event) throws MessagingException    {        String eventComponentName = event.getService().getName();        if (!assignedComponentName.equals(eventComponentName))        {            IllegalArgumentException iex = new IllegalArgumentException(                "This receiver is assigned to service: " + assignedComponentName                                + " but has received an event for service: " + eventComponentName                                + ". Please check your config to make sure each service"                                + "has its own instance of IdempotentReceiver.");            throw new RoutingException(event.getMessage(), event.getEndpoint(), iex);        }        String id = this.getIdForEvent(event);        try        {            if (store.storeObject(id, id))            {                return new MuleEvent[]{event};            }            else            {                return null;            }        }        catch (Exception e)        {            throw new RoutingException(CoreMessages.failedToWriteMessageToStore(id, assignedComponentName),                event.getMessage(), event.getEndpoint(), e);        }    }    protected String getIdForEvent(MuleEvent event) throws MessagingException    {        return ExpressionEvaluatorManager.parse(idExpression, event.getMessage(), true);    }    public String getIdExpression()    {        return idExpression;    }    public void setIdExpression(String idExpression)    {        this.idExpression = idExpression;    }    public ObjectStore getStore()    {        return store;    }    public void setStore(ObjectStore store)    {        this.store = store;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -