rabbitMQ使用总结

一、rabbitMQ安装

百度搜索相关教程,官网下载erlang、rabbitmq-server的exe文件,点击直接安装就行。

注意:erlang版本与rabbitmq-server版本需要匹配,比如我下载的rabbitmq-server-3.7.6版本,对应的erlang版本只能在版本号为19.3-20.3内的版本。http://www.rabbitmq.com/which-erlang.html可以看到相关版本关系。

二、管理界面

如果需要安装管理界面,进入rabbitmq-server的安装目录下sbin目录,执行rabbitmq-plugins enable rabbitmq_management,完成安装。

安装成功后启动服务可通过http://localhost:15672地址访问,通过默认的guest(密码为guest)账号可以登录进行管理。

guest账户只能通过localhost访问,通过guest登陆后,可以进入Admin页面,添加用户Add user,添加用户后点击用户名进入权限设置页面,设置权限set permission。这样就可以通过IP(即通过远程)进行访问了。

三、java客户端连接server

1、引入依赖包

<dependency>
            <groupId>com.rabbitmq</groupId>
            <artifactId>amqp-client</artifactId>
            <version>4.0.0</version>

</dependency>

2、生产者

         //创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //设置RabbitMQ相关信息
//        factory.setHost("localhost");// 本机访问

        factory.setHost("192.168.144.56");// 远程接入
        factory.setUsername("test");// 远程接入
        factory.setPassword("123456");// 远程接入
        factory.setPort(5672);// 远程接入
        //创建一个新的连接
        Connection connection = factory.newConnection();
        //创建一个通道
        Channel channel = connection.createChannel();
        //  声明一个队列        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        String message = "Hello world!";
        //发送消息到队列中
        channel.basicPublish("", QUEUE_NAME, null, message.getBytes("UTF-8"));
        System.out.println("Producer message: +'" + message + "'");
        //关闭通道和连接
        channel.close();
        connection.close();

3、消费者

            factory = new ConnectionFactory();
//            factory.setHost("localhost");// 本机访问
            factory.setHost("192.168.144.56");// 远程连接
            factory.setUsername("test");// 远程连接
            factory.setPassword("123456");// 远程连接
            factory.setPort(5672);// 远程连接
            connection = factory.newConnection();
            channel = connection.createChannel();
            channel.queueDeclare(QUEUE_NAME, false, false, false, null);
            QueueingConsumer consumer = new QueueingConsumer(channel);
            channel.basicConsume(QUEUE_NAME, true,consumer);
            while(true){
                QueueingConsumer.Delivery delivery = consumer.nextDelivery();
                String message = new String(delivery.getBody());
                System.out.println("Received message'" + message + "'");

            }

4、默认端口说明

4369:epmd (RabbitMQ 节点发现服务)

5672:AMQP客户端通信端口

15672:管理端口

25672:节点间通信端口,动态分配(默认以amqp端口+20000)

详细端口说明参见官网:http://www.rabbitmq.com/install-windows.html#windows-ports

猜你喜欢

转载自blog.csdn.net/long2010110/article/details/80814592