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


Java DeliveryMode.PERSISTENT屬性代碼示例

本文整理匯總了Java中javax.jms.DeliveryMode.PERSISTENT屬性的典型用法代碼示例。如果您正苦於以下問題:Java DeliveryMode.PERSISTENT屬性的具體用法?Java DeliveryMode.PERSISTENT怎麽用?Java DeliveryMode.PERSISTENT使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在javax.jms.DeliveryMode的用法示例。


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

示例1: setDeliveryMode

@Override
public JMSProducer setDeliveryMode(int deliveryMode) {
    switch (deliveryMode) {
        case DeliveryMode.PERSISTENT:
        case DeliveryMode.NON_PERSISTENT:
            this.deliveryMode = deliveryMode;
            return this;
        default:
            throw new JMSRuntimeException(String.format("Invalid DeliveryMode specified: %d", deliveryMode));
    }
}
 
開發者ID:messaginghub,項目名稱:pooled-jms,代碼行數:11,代碼來源:JmsPoolJMSProducer.java

示例2: setJMSDeliveryMode

@Override
public void setJMSDeliveryMode(int deliveryMode) throws JMSException {
    switch (deliveryMode) {
        case DeliveryMode.PERSISTENT:
            persistent = true;
            break;
        case DeliveryMode.NON_PERSISTENT:
            persistent = false;
            break;
        default:
            throw new JMSException(String.format("Invalid DeliveryMode specific: %d", deliveryMode));
    }
}
 
開發者ID:messaginghub,項目名稱:pooled-jms,代碼行數:13,代碼來源:MockJMSMessage.java

示例3: setDeliveryMode

@Override
public void setDeliveryMode(int deliveryMode) throws JMSException {
    checkClosed();
    switch (deliveryMode) {
        case DeliveryMode.PERSISTENT:
        case DeliveryMode.NON_PERSISTENT:
            this.deliveryMode = deliveryMode;
            break;
        default:
            throw new JMSException(String.format("Invalid DeliveryMode specified: %d", deliveryMode));
    }
}
 
開發者ID:messaginghub,項目名稱:pooled-jms,代碼行數:12,代碼來源:MockJMSMessageProducer.java

示例4: getDeliveryMode

private int getDeliveryMode() {
    if (persistentDelivery) {
        return DeliveryMode.PERSISTENT;
    }

    return DeliveryMode.NON_PERSISTENT;
}
 
開發者ID:apache,項目名稱:bahir-flink,代碼行數:7,代碼來源:AMQSink.java

示例5: set

@Override
public void set(Message message, Object value) throws MessageFormatException {
    Integer rc = (Integer) TypeConversionSupport.convert(value, Integer.class);
    if (rc == null) {
        Boolean bool = (Boolean) TypeConversionSupport.convert(value, Boolean.class);
        if (bool == null) {
            throw new MessageFormatException("Property JMSDeliveryMode cannot be set from a " + value.getClass().getName() + ".");
        }
        else {
            rc = bool.booleanValue() ? DeliveryMode.PERSISTENT : DeliveryMode.NON_PERSISTENT;
        }
    }
    ((ActiveMQMessage) message).setJMSDeliveryMode(rc);
}
 
開發者ID:DiamondLightSource,項目名稱:daq-eclipse,代碼行數:14,代碼來源:ActiveMQMessage.java

示例6: setUp

@Override
public void setUp() throws Exception {
   topic = true;
   durable = true;
   deliveryMode = DeliveryMode.PERSISTENT;
   super.setUp();
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:7,代碼來源:JmsDurableTopicWildcardSendReceiveTest.java

示例7: setUp

/**
 * Set up the test with a queue and persistent delivery mode.
 *
 * @see junit.framework.TestCase#setUp()
 */
@Override
protected void setUp() throws Exception {
   topic = false;
   deliveryMode = DeliveryMode.PERSISTENT;
   super.setUp();
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:11,代碼來源:JmsDurableQueueWildcardSendReceiveTest.java

示例8: testDurableQueueMessage

public void testDurableQueueMessage() throws Exception {
   super.topic = false;
   deliveryMode = DeliveryMode.PERSISTENT;
   durableSubscriber = false;
   doTest();
   validateConsumerPrefetch(this.getDestinationString(), 0);
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:7,代碼來源:DeadLetterTestSupport.java

示例9: testDLQBrowsing

public void testDLQBrowsing() throws Exception {
   super.topic = false;
   deliveryMode = DeliveryMode.PERSISTENT;
   durableSubscriber = false;
   messageCount = 1;

   connection.start();

   ActiveMQConnection amqConnection = (ActiveMQConnection) connection;
   rollbackCount = amqConnection.getRedeliveryPolicy().getMaximumRedeliveries() + 1;
   LOG.info("Will redeliver messages: " + rollbackCount + " times");

   sendMessages();

   // now lets receive and rollback N times
   for (int i = 0; i < rollbackCount; i++) {
      makeConsumer();
      Message message = consumer.receive(5000);
      assertNotNull("No message received: ", message);

      session.rollback();
      LOG.info("Rolled back: " + rollbackCount + " times");
      consumer.close();
   }

   makeDlqBrowser();
   browseDlq();
   dlqBrowser.close();
   session.close();
   Thread.sleep(1000);
   session = connection.createSession(transactedMode, acknowledgeMode);
   Queue testQueue = new ActiveMQQueue("ActiveMQ.DLQ.Queue.ActiveMQ.DLQ.Queue." + getClass().getName() + "." + getName());
   MessageConsumer testConsumer = session.createConsumer(testQueue);
   assertNull("The message shouldn't be sent to another DLQ", testConsumer.receive(1000));

}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:36,代碼來源:IndividualDeadLetterTest.java

示例10: setJMSDeliveryMode

@Override
public void setJMSDeliveryMode(final int deliveryMode) throws JMSException {
   if (deliveryMode == DeliveryMode.PERSISTENT) {
      message.setDurable(true);
   } else if (deliveryMode == DeliveryMode.NON_PERSISTENT) {
      message.setDurable(false);
   } else {
      throw ActiveMQJMSClientBundle.BUNDLE.illegalDeliveryMode(deliveryMode);
   }
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:10,代碼來源:ActiveMQMessage.java

示例11: setDeliveryMode

@Override
public void setDeliveryMode(final int deliveryMode) throws JMSException {
   checkClosed();
   if (deliveryMode != DeliveryMode.NON_PERSISTENT && deliveryMode != DeliveryMode.PERSISTENT) {
      throw ActiveMQJMSClientBundle.BUNDLE.illegalDeliveryMode(deliveryMode);
   }

   defaultDeliveryMode = deliveryMode;
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:9,代碼來源:ActiveMQMessageProducer.java

示例12: getJMSDeliveryMode

@Override
public int getJMSDeliveryMode() throws JMSException {
    return persistent ? DeliveryMode.PERSISTENT : DeliveryMode.NON_PERSISTENT;
}
 
開發者ID:messaginghub,項目名稱:pooled-jms,代碼行數:4,代碼來源:MockJMSMessage.java

示例13: configure

/**
 * Configure this class.
 * 
 * @param props initial configuration
 *
 * @throws ConnectException   Operation failed and connector should stop.
 */
public void configure(Map<String, String> props) {
    String queueManager = props.get(MQSinkConnector.CONFIG_NAME_MQ_QUEUE_MANAGER);
    String connectionNameList = props.get(MQSinkConnector.CONFIG_NAME_MQ_CONNECTION_NAME_LIST);
    String channelName = props.get(MQSinkConnector.CONFIG_NAME_MQ_CHANNEL_NAME);
    String queueName = props.get(MQSinkConnector.CONFIG_NAME_MQ_QUEUE);
    String userName = props.get(MQSinkConnector.CONFIG_NAME_MQ_USER_NAME);
    String password = props.get(MQSinkConnector.CONFIG_NAME_MQ_PASSWORD);
    String builderClass = props.get(MQSinkConnector.CONFIG_NAME_MQ_MESSAGE_BUILDER);
    String mbj = props.get(MQSinkConnector.CONFIG_NAME_MQ_MESSAGE_BODY_JMS);
    String timeToLive = props.get(MQSinkConnector.CONFIG_NAME_MQ_TIME_TO_LIVE);
    String persistent = props.get(MQSinkConnector.CONFIG_NAME_MQ_PERSISTENT);
    String sslCipherSuite = props.get(MQSinkConnector.CONFIG_NAME_MQ_SSL_CIPHER_SUITE);
    String sslPeerName = props.get(MQSinkConnector.CONFIG_NAME_MQ_SSL_PEER_NAME);

    try {
        mqConnFactory = new MQConnectionFactory();
        mqConnFactory.setTransportType(WMQConstants.WMQ_CM_CLIENT);
        mqConnFactory.setQueueManager(queueManager);
        mqConnFactory.setConnectionNameList(connectionNameList);
        mqConnFactory.setChannel(channelName);

        queue = new MQQueue(queueName);

        this.userName = userName;
        this.password = password;

        queue.setMessageBodyStyle(WMQConstants.WMQ_MESSAGE_BODY_MQ);
        if (mbj != null) {
            if (Boolean.parseBoolean(mbj)) {
                queue.setMessageBodyStyle(WMQConstants.WMQ_MESSAGE_BODY_JMS);
            }
        }

        if (timeToLive != null) {
            this.timeToLive = Long.parseLong(timeToLive);
        }
        if (persistent != null) {
            this.deliveryMode = Boolean.parseBoolean(persistent) ? DeliveryMode.PERSISTENT : DeliveryMode.NON_PERSISTENT;
        }

        if (sslCipherSuite != null) {
            mqConnFactory.setSSLCipherSuite(sslCipherSuite);
            if (sslPeerName != null)
            {
                mqConnFactory.setSSLPeerName(sslPeerName);
            }
        }
    }
    catch (JMSException | JMSRuntimeException jmse) {
        log.debug("JMS exception {}", jmse);
        throw new ConnectException(jmse);
    }

    try {
        Class<? extends MessageBuilder> c = Class.forName(builderClass).asSubclass(MessageBuilder.class);
        builder = c.newInstance();
    }
    catch (ClassNotFoundException | IllegalAccessException | InstantiationException | NullPointerException exc) {
        log.debug("Could not instantiate message builder {}", builderClass);
        throw new ConnectException("Could not instantiate message builder", exc);
    }
}
 
開發者ID:ibm-messaging,項目名稱:kafka-connect-mq-sink,代碼行數:69,代碼來源:JMSWriter.java

示例14: getMessageHeaders

/**
 * Returns a String with the JMS Message Header values.
 *
 * @param message JMS Message
 * @return String with message header values.
 */
public static String getMessageHeaders(Message message) {
    final StringBuilder response = new StringBuilder(256);
    try {
        response.append("JMS Message Header Attributes:");
        response.append("\n   Correlation ID: ");
        response.append(message.getJMSCorrelationID());

        response.append("\n   Delivery Mode: ");
        if (message.getJMSDeliveryMode() == DeliveryMode.PERSISTENT) {
            response.append("PERSISTANT");
        } else {
            response.append("NON-PERSISTANT");
        }

        final Destination destination = message.getJMSDestination();

        response.append("\n   Destination: ");
        response.append((destination == null ? null : destination
            .toString()));

        response.append("\n   Expiration: ");
        response.append(new Date(message.getJMSExpiration()));

        response.append("\n   Message ID: ");
        response.append(message.getJMSMessageID());

        response.append("\n   Priority: ");
        response.append(message.getJMSPriority());

        response.append("\n   Redelivered: ");
        response.append(message.getJMSRedelivered());

        final Destination replyTo = message.getJMSReplyTo();
        response.append("\n   Reply to: ");
        response.append((replyTo == null ? null : replyTo.toString()));

        response.append("\n   Timestamp: ");
        response.append(new Date(message.getJMSTimestamp()));

        response.append("\n   Type: ");
        response.append(message.getJMSType());

        response.append("\n\n");

    } catch (JMSException e) {
        e.printStackTrace();
    }

    return new String(response);
}
 
開發者ID:johrstrom,項目名稱:cloud-meter,代碼行數:56,代碼來源:BaseJMSSampler.java

示例15: sample

/**
 * {@inheritDoc}
 */
@Override
public SampleResult sample(Entry entry) {
    SampleResult res = new SampleResult();
    res.setSampleLabel(getName());
    res.setSamplerData(getContent());
    res.setSuccessful(false); // Assume failure
    res.setDataType(SampleResult.TEXT);
    res.sampleStart();

    try {
        TextMessage msg = createMessage();
        if (isOneway()) {
            int deliveryMode = isNonPersistent() ? 
                    DeliveryMode.NON_PERSISTENT:DeliveryMode.PERSISTENT;
            producer.send(msg, deliveryMode, Integer.parseInt(getPriority()), 
                    Long.parseLong(getExpiration()));
            res.setRequestHeaders(Utils.messageProperties(msg));
            res.setResponseOK();
            res.setResponseData("Oneway request has no response data", null);
        } else {
            if (!useTemporyQueue()) {
                msg.setJMSReplyTo(receiveQueue);
            }
            Message replyMsg = executor.sendAndReceive(msg,
                    isNonPersistent() ? DeliveryMode.NON_PERSISTENT : DeliveryMode.PERSISTENT, 
                    Integer.parseInt(getPriority()), 
                    Long.parseLong(getExpiration()));
            res.setRequestHeaders(Utils.messageProperties(msg));
            if (replyMsg == null) {
                res.setResponseMessage("No reply message received");
            } else {
                if (replyMsg instanceof TextMessage) {
                    res.setResponseData(((TextMessage) replyMsg).getText(), null);
                } else {
                    res.setResponseData(replyMsg.toString(), null);
                }
                res.setResponseHeaders(Utils.messageProperties(replyMsg));
                res.setResponseOK();
            }
        }
    } catch (Exception e) {
        log.warn(e.getLocalizedMessage(), e);
        if (thrown != null){
            res.setResponseMessage(thrown.toString());
        } else {                
            res.setResponseMessage(e.getLocalizedMessage());
        }
    }
    res.sampleEnd();
    return res;
}
 
開發者ID:johrstrom,項目名稱:cloud-meter,代碼行數:54,代碼來源:JMSSampler.java


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