突然不发消息给ActiveMQ但能接收

        今天项目在联调过程中,ActiveMQ突然不好使了。在此之前一月内,项目组的人都没有去修改、重启过MQ服务。

        虽然现在知道是由于权限的问题导致只能收不能发(站在ActiveMQ角度是收不到,但可以发)。只是到现在还不知道原来没变过的代码,怎么以前可以用,现在却不行了???

       通过查询示例代码,发现有connectionFactory.setUserName("system");由此联想到,应该跟访问权限的设计有关系。

     查询activemq.home/conf/果然有activemq-security.xml,有关于安全方面的配置示例。查询资料,可以通过设置anonymousAccessAllowed="false"使得MQ不需要密码访问。

     去掉密码是不安全的,但之前没有设置过,真不知道怎么可以突然不行了。疑惑疑惑……

 

 

		<plugins>
			<!-- Configure authentication; Username, passwords and groups -->
			<simpleAuthenticationPlugin anonymousAccessAllowed="false">
				<users>
					<authenticationUser username="system" password="${activemq.password}"
						groups="users,admins"/>
					<authenticationUser username="user" password="${guest.password}"
						groups="users"/>
					<authenticationUser username="guest" password="${guest.password}" groups="guests"/>
				</users>
			</simpleAuthenticationPlugin>
        </plugins>

 

 

在Java中使用ActiveMQ接收消息通常涉及以下几个步骤。首先,你需要添加相关的依赖,比如Apache ActiveMQ的AMQSTools库。以下是基本的消费者示例: ```java import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.command.ActiveMQTextMessage; import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.MessageConsumer; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import java.util.concurrent.ExecutorService; public class AMQJMSConsumer { private static final String QUEUE_NAME = "YOUR_QUEUE_NAME"; public static void main(String[] args) { ExecutorService executorService = Executors.newSingleThreadExecutor(); // 创建连接工厂 ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616"); try { // 获取连接 Connection connection = connectionFactory.createConnection(); connection.start(); // 开启事务式Session Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); // 创建消息消费者 MessageConsumer consumer = session.createConsumer(session.createQueue(QUEUE_NAME)); System.out.println("【消费者】开始监听:" + QUEUE_NAME); while (true) { TextMessage message = (TextMessage) consumer.receive(1000); // 设置超时时间,单位毫秒 if (message != null) { executorService.submit(() -> processMessage(message.getText())); } } } catch (Exception e) { e.printStackTrace(); } finally { // 关闭资源 if (executorService != null) { executorService.shutdownNow(); } } } private static void processMessage(String message) { // 处理接收到的消息 System.out.println("Received message: " + message); } } ``` 这个例子中,创建了一个单线程的ExecutorService来异步处理接收到的消息。`processMessage`方法是你自定义的实际业务逻辑,将接收到的文本消息内容打印出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值