You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@activemq.apache.org by "Justin Bertram (JIRA)" <ji...@apache.org> on 2018/01/23 15:21:00 UTC
[jira] [Closed] (ARTEMIS-1236) Diverts are not reloaded on server
restart
[ https://issues.apache.org/jira/browse/ARTEMIS-1236?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Justin Bertram closed ARTEMIS-1236.
-----------------------------------
Resolution: Duplicate
> Diverts are not reloaded on server restart
> ------------------------------------------
>
> Key: ARTEMIS-1236
> URL: https://issues.apache.org/jira/browse/ARTEMIS-1236
> Project: ActiveMQ Artemis
> Issue Type: Bug
> Components: Broker
> Affects Versions: 2.1.0
> Reporter: Dmitry
> Priority: Major
>
> When diverts are created dynamically they are lost after server restart.
> {code}
> import static org.testng.Assert.assertEquals;
> import static org.testng.Assert.assertNull;
> import java.io.File;
> import java.io.IOException;
> import java.nio.file.Files;
> import java.util.Arrays;
> import java.util.HashMap;
> import java.util.HashSet;
> import java.util.Map;
> import org.apache.activemq.artemis.api.core.TransportConfiguration;
> import org.apache.activemq.artemis.core.config.Configuration;
> import org.apache.activemq.artemis.core.config.DivertConfiguration;
> import org.apache.activemq.artemis.core.config.impl.ConfigurationImpl;
> import org.apache.activemq.artemis.core.remoting.impl.netty.NettyAcceptorFactory;
> import org.apache.activemq.artemis.core.remoting.impl.netty.NettyConnectorFactory;
> import org.apache.activemq.artemis.core.remoting.impl.netty.TransportConstants;
> import org.apache.activemq.artemis.core.settings.impl.AddressFullMessagePolicy;
> import org.apache.activemq.artemis.core.settings.impl.AddressSettings;
> import org.apache.activemq.artemis.jms.client.ActiveMQConnectionFactory;
> import org.apache.activemq.artemis.jms.server.config.JMSConfiguration;
> import org.apache.activemq.artemis.jms.server.config.impl.JMSConfigurationImpl;
> import org.apache.activemq.artemis.jms.server.config.impl.JMSQueueConfigurationImpl;
> import org.apache.activemq.artemis.jms.server.embedded.EmbeddedJMS;
> import org.springframework.jms.core.JmsTemplate;
> import org.testng.annotations.Test;
> public class RestartTest {
> @Test
> public void divertsReloaded() throws Exception {
> File tempDirectory = Files.createTempDirectory("").toFile();
> tempDirectory.deleteOnExit();
> String path = tempDirectory.getAbsolutePath();
> EmbeddedJMS jms = createServer(path);
>
> DivertConfiguration divert = new DivertConfiguration();
> divert.setAddress("from");
> divert.setForwardingAddress("to");
> divert.setName("divert");
> divert.setExclusive(true);
> jms.getActiveMQServer().deployDivert(divert);
>
> JmsTemplate template = queueTemplate();
>
> template.convertAndSend("from", "test");
> String received = (String) template.receiveAndConvert("to");
> assertEquals(received, "test");
> assertNull(template.receiveAndConvert("from"));
> jms.stop();
> Thread.sleep(1000);
>
> jms = createServer(path);
>
> template.convertAndSend("from", "test");
> received = (String) template.receiveAndConvert("to");
> assertEquals(received, "test");
> received = (String) template.receiveAndConvert("from");
> assertNull(received);
> }
> private EmbeddedJMS createServer(String path) throws IOException, Exception {
> EmbeddedJMS jms = new EmbeddedJMS();
> Configuration configuration = new ConfigurationImpl();
> HashSet<TransportConfiguration> transports = new HashSet<TransportConfiguration>();
> Map<String, Object> transportConfig = new HashMap<String, Object>();
> transportConfig.put(TransportConstants.HOST_PROP_NAME, "127.0.0.1");
> transportConfig.put(TransportConstants.PORT_PROP_NAME, 61616);
> transports.add(new TransportConfiguration(NettyAcceptorFactory.class.getName(), transportConfig));
> configuration.addConnectorConfiguration("self", new TransportConfiguration(NettyConnectorFactory.class.getName(), transportConfig));
> configuration.setAcceptorConfigurations(transports);
>
> configuration.setPagingDirectory(path + "/data/paging");
> configuration.setBindingsDirectory(path + "/data/bindings");
> configuration.setJournalDirectory(path + "/data/journal");
> configuration.setLargeMessagesDirectory(path + "/data/large-messages");
> configuration.setPersistenceEnabled(true);
> configuration.setSecurityEnabled(false);
> AddressSettings defaultAddressSettings = new AddressSettings();
> defaultAddressSettings
> .setAddressFullMessagePolicy(AddressFullMessagePolicy.PAGE)
> .setMaxDeliveryAttempts(-1)
> .setRedeliveryDelay(0)
> .setRedistributionDelay(0)
> .setAutoCreateAddresses(false)
> .setAutoCreateQueues(false)
> .setAutoDeleteAddresses(false)
> .setAutoDeleteQueues(false)
> .setMaxSizeBytes(10L * 1024 * 1024)
> .setPageSizeBytes(5L * 1024 * 1024);
> configuration.addAddressesSetting("#", new AddressSettings(defaultAddressSettings));
>
> JMSConfiguration jmsConfiguration = new JMSConfigurationImpl();
> JMSQueueConfigurationImpl queue1 = new JMSQueueConfigurationImpl();
> queue1.setName("from");
> queue1.setDurable(true);
> JMSQueueConfigurationImpl queue2 = new JMSQueueConfigurationImpl();
> queue2.setName("to");
> queue2.setDurable(true);
> jmsConfiguration.setQueueConfigurations(Arrays.asList(queue1, queue2));
> jms.setJmsConfiguration(jmsConfiguration);
> jms.setConfiguration(configuration);
>
> jms.start();
> return jms;
> }
>
> private ActiveMQConnectionFactory jmsConnectionFactory() {
> Map<String, Object> params = new HashMap<String, Object>();
> params.put(TransportConstants.HOST_PROP_NAME, "127.0.0.1");
> params.put(TransportConstants.PORT_PROP_NAME, 61616);
> TransportConfiguration transportConfiguration = new TransportConfiguration(
> NettyConnectorFactory.class.getName(), params);
> ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(false, transportConfiguration);
> connectionFactory.setBlockOnAcknowledge(false);
> connectionFactory.setBlockOnDurableSend(false);
> connectionFactory.setBlockOnNonDurableSend(false);
> return connectionFactory;
> }
>
> private JmsTemplate queueTemplate() {
> JmsTemplate jmsTemplate = new JmsTemplate();
> jmsTemplate.setConnectionFactory(jmsConnectionFactory());
> jmsTemplate.setReceiveTimeout(1000);
> return jmsTemplate;
> }
> }
> {code}
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)