目录
doker安装:
RabitMq安装:
java链接
doker安装:
参考链接(非常详细):
docker安装以及部署_docker bu shuminio_春风与麋鹿的博客-CSDN博客
安装好后开启doker
//启动docker服务
systemctl start docker
//停止docker服务
systemctl stop docker
//重启docker服务
systemctl restart docker
//查看docker服务状态
systemctl status docker
RabitMq安装:
1. 拉取do'ke中的rabbitmq镜像
docker pull rabbitmq:3.7.16-management
2.启动
docker run -d --hostname my-rabbit -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -p 5672:5672 -p 15672:15672 rabbitmq:3.7.16-management参数解释:
RABBITMQ_DEFAULT_USER=admin(账号为admin)可以自己随意改
RABBITMQ_DEFAULT_PASS=admin(登录密码为admin)可以自己随意改
-p 5672:5672 :rabbitmq的默认端口,映射到虚拟机5672端口,程序中,访问用
-p 15672:15672:rabbitmq的浏览器访问登录界面端口,映射到虚拟机15672端口,浏览器访问端口
3.浏览器访问
输入虚拟机ip和端口号进行访问
java链接
链接之前在防火墙中开发5672端口,否则会连接超时
#关闭防火墙
systemctl stop firewalld
#查看开启了哪些端口号
firewall-cmd --list-ports
#添加端口号
sudo firewall-cmd --permanent --zone=public --add-port=5672/tcp
#操作防火墙后要重启防火墙
firewall-cmd --reload
生产者:
public class Send {//Ctrl+Shift+U大写转换public static final String QUEUE_NAME = "hello";//发消息public static void main(String[] args) throws IOException, TimeoutException {//创建一个工厂ConnectionFactory factory = new ConnectionFactory();//工厂IP连接RabbitMQ的队列factory.setHost("192.168.29.129");//port可不设置,默认5672
// factory.setPort(5672);//用户名factory.setUsername("admin");//密码factory.setPassword("admin");//创建连接Connection connection = factory.newConnection();//获取信道Channel channel = connection.createChannel();/*** 生成一个队列* 1.队列名称* 2.队列里面的消息是否持久化(磁盘)默认情况消息存储在内存中* 3.该队列是否只供一个消费者进行消费是否进行消息共享,false可以多个消费者消费 true:只能一个消费者消费* 4.是否自动删除最后一个消费者端开连接以后该队一句是否自动删除 true自动删除 false不自动删除* 5.其它参数*/channel.queueDeclare(QUEUE_NAME,false,false,false,null);//发消息String message = "Hello World!";//初次使用/*** 发送一个消费* 1.发送到哪个交换机* 2.路由的Key值是哪个本次是队列的名称* 3.其它参数信息* 4.发送消息的消息体*/channel.basicPublish("",QUEUE_NAME,null,message.getBytes());System.out.println("消息发送完毕");}
}
启动:
页面显示消息已发送成功
消费者:
public class Recive {public static final String QUEEN_NAME = "hello";//接收消息public static void main(String[] args) throws Exception {//创建连接工厂ConnectionFactory factory = new ConnectionFactory();factory.setHost("192.168.29.129");//port可不设置,默认5672factory.setPort(5672);//用户名factory.setUsername("admin");//密码factory.setPassword("admin");Connection connection = factory.newConnection();//用连接创建信道Channel channel = connection.createChannel();/*** 消费者消费消息*1.消费哪个队列* 2.消费成功之后是否要自动应答 true 代表的自动应答 false 代表手动应答* 3.消费者未成功消费的回调* 4.消费者取消消费的回调*///声明: 接收消息DeliverCallback deliverCallback = (consumerTag,message) ->{System.out.println(message);System.out.println(new String(message.getBody()));};//取消消息时的回调CancelCallback cancelCallback = consumerTag ->{System.out.println("消费消息被中断");};channel.basicConsume(QUEEN_NAME,true,deliverCallback,cancelCallback);}
}
启动:消息接收成