rabbitmq实例_rabbitmq创建队列

rabbitmq实例_rabbitmq创建队列RabbitMQ简介RabbitMQ是一个受欢迎的消息代理,通常用于应用程序之间或者程序的不同组件之间通过消息来进行集成。具有高可用高并发的优点,适合集群服务器。采用Erlang实现,对主要的编程语言都有客户端支持。RabbitMQ环境配置linux下环境配置我用的是centos6.5版本。先从这个地址下载安装包下载地址$tar-zxvfotp_…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

RabbitMQ简介

RabbitMQ是一个受欢迎的消息代理,通常用于应用程序之间或者程序的不同组件之间通过消息来进行集成。具有高可用高并发的优点,适合集群服务器。采用 Erlang实现, 对主要的编程语言都有客户端支持。

RabbitMQ环境配置

linux下环境配置

我用的是centos 6.5版本。

先从这个地址下载安装包

下载地址

$ tar -zxvf otp_src_18.3.tar.gz 

$ cd otp_src_18.3

$ ./configure --prefix=/usr/local/erlang --with-ssl -enable-threads -enable-smmp-support -enable-kernel-poll --enable-hipe --without-javac

$ make

$ sudo make install

配置环境变量

vim /etc/profile

在文件末尾添加下面文字:

ERLANG_HOME=/usr/local/erlang
PATH=$ERLANG_HOME/bin:$PATH
export ERLANG_HOME
export PATH

使环境变量生效

source /etc/profile

然后下载RabbitMQ,下载地址

先安装依赖

$ sudo yum install xmlto
$ xz -d rabbitmq-server-generic-unix-3.6.1.tar.xz

$ tar -xvf rabbitmq-server-generic-unix-3.6.1.tar 

# 移动目录
$ sudo cp -rf ./rabbitmq_server-3.6.1/ /usr/local/

$ cd /usr/local

#改名字
$  mv rabbitmq_server-3.6.1 rabbitmq-3.6.1

# 安装web管理插件
$ cd sbin/

$ ./rabbitmq-plugins enable rabbitmq_management

启动和关闭服务

$ ./rabbitmq-server

# 后台启动
$ ./rabbitmq-server -detached

# 关闭
$ ./rabbitmqctl stop

登录web管理端

启动rabbitmq,然后浏览器输入
http://10.0.0.221:15672/

这个ip地址是你实际安装的主机的ip,请根据实际情况修改。

这里写图片描述

下面配置登录账号

$ ./rabbitmqctl add_user pony 123456
Creating user "pony" ...

$ ./rabbitmqctl set_user_tags pony administrator       
Setting tags for user "pony" to [administrator] ...

刷新下,用刚才创建的账号登录,如下:

这里写图片描述

有一点要注意,如果主机配有防火墙,要把用到的端口都打开

-A INPUT -p tcp -m state --state NEW -m tcp --dport 15672 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 25672 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 5672 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 4369 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 5671 -j ACCEPT

windows下环境配置

erlang下载地址

rabbitmq下载地址

可以根据需要下载自己所需要的版本,我这里下载的分别是:

otp_win64_18.3.exe和rabbitmq-server-3.6.9.exe

默认方式安装otp_win64_18.3.exe,完成后,配置环境变量

ERLANG_HOME C:\Program Files\erl7.3

添加到PATH

%ERLANG_HOME%\bin;

默认方式安装rabbitmq-server-3.6.9.exe,完成后,配置环境变量

RABBITMQ_SERVER C:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.9

添加到PATH

%RABBITMQ_SERVER%\sbin;

进入sbin目录打开一个控制台,安装web管理插件

C:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.9\sbin>rabbitmq-plugins.bat enable rabbitmq_management

然后重启下服务使上面的配置生效(注意这里要使用管理员打开cmd命令行,路径无影响),

C:\WINDOWS\system32>net stop RabbitMQ && net start RabbitMQ
RabbitMQ 服务正在停止.
RabbitMQ 服务已成功停止。

RabbitMQ 服务正在启动 .
RabbitMQ 服务已经启动成功。


C:\WINDOWS\system32>

打开浏览器,输入http://localhost:15672/,可以正常访问。由于我是在本机安装,所以这里是localhost。

接下来配置一个账号并赋予管理员权限(当然要确保是启动状态),

C:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.9\sbin>rabbitmqctl.bat add_user pony 123456
Creating user "pony" ...

C:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.9\sbin>rabbitmqctl.bat set_user_tags pony administrator
Setting tags for user "pony" to [administrator] ...

在web端用这个账号登录,可以成功!

java调用示例

我的开发环境是myeclipse+win10,windows环境下已经按照前面章节配置好了rabbitmq服务。**然后保持启动状态。**java要使用rabbitmq需要依赖一个客户端。下载地址

如果用maven的话就不用下载,配置文件加上依赖描述即可。

我这里新建两个工程,分别为RabbitMQDemo-P(表示生产者)和RabbitMQDemo-C(表示消费者),两个工程运行起来后就代表两个独立的进程通过消息队列通信。生产者不断的往消息队列发送消息,而消费者不断的从队列取消息。工程中导入前面下载的客户端依赖包。

源码来自:rabbitmq-tutorials

eclipse工程源码下载地址

这里写图片描述

先生产者的代码:


private final static String QUEUE_NAME = "hello";
	
	public static void main(String[] args) throws Exception{ 
   
		// TODO Auto-generated method stub
		
		ConnectionFactory factory = new ConnectionFactory();
	    factory.setHost("localhost");//因为两个进程在同一个机器上
	    Connection connection = null;
	    Channel channel = null;
	    
		connection = factory.newConnection();
		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] Sent '" + message + "'");
		    
		channel.close();
		connection.close();
	}

比较简单,涉及到的API具体说明可以自行搜索学习。运行一次就往名为hello的队列上发布一条消息:“Hello World”,然后进程结束。

消费者稍微复杂一点,

private final static String QUEUE_NAME = "hello";
	
	public static void main(String[] args) throws Exception{ 
   
		
		ConnectionFactory factory = new ConnectionFactory();
	    factory.setHost("localhost");
	    Connection connection = factory.newConnection();
	    Channel channel = connection.createChannel();

	    channel.queueDeclare(QUEUE_NAME, false, false, false, null);
	    System.out.println(" [*] Waiting for messages. To exit press CTRL+C");

	    Consumer consumer = new DefaultConsumer(channel) { 
   
	      @Override
	      public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)
	          throws IOException { 
   
	        String message = new String(body, "UTF-8");
	        System.out.println(" [Consumer] Received '" + message + "'");
	      }
	    };
	    channel.basicConsume(QUEUE_NAME, true, consumer);
		
	}

Channel.basicConsume方法将Consumer与消息队列绑定,它的定义如下:

String basicConsume(String queue, boolean autoAck, Consumer callback) throws IOException 

第一个参数是Consumer绑定的队列名,第二个参数是自动确认标志,如果为true,表示Consumer接受到消息后,会自动发确认消息(Ack消息)给消息队列,消息队列会将这条消息从消息队列里删除,第三个参数就是Consumer对象,用于处理接收到的消息。

第三个参数其实是个回调,当消费者收到消息时,会调用Consumer对象的handleDelivery方法。我们这里重写了这个方法,收到消息之后打印出来。

先运行消费者,如下:

 [*] Waiting for messages. To exit press CTRL+C

开始等待消息。

再运行生产者,如下:

 [Producer] Sent 'Hello World!'

再次看下消费者的控制台信息,接收到消息:

 [*] Waiting for messages. To exit press CTRL+C
 [Consumer] Received 'Hello World!'

在这里插入图片描述
欢迎大家关注我的公众号

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189011.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm怎么配置python环境anaconda_ug编程电脑配置要求

    pycharm怎么配置python环境anaconda_ug编程电脑配置要求1.介绍Python:一种解释型、面向对象、动态数据类型的高级程序设计语言。PyCharm:一款好用的集成开发环境。Conda:Python环境管理器,方便我们管理和切换编程环境。2.下载2.1Conda下载Miniconda下载链接Anaconda下载链接Miniconda是Anaconda的压缩版,Miniconda只包含conda的核心内容,Anaconda中包含了Spyder集成开发环境等扩充内容。Miniconda的功能足矣。根据计算机的实际情况选择下载安装包,上图中Py

    2022年8月28日
    3
  • xaml是什么

    xaml是什么也就是说在开发一个应用程序时 我们可以将开发工作分成开发人员和设计人员两个团体分别进行 各自负责后台程序代码逻辑和前台程序界面的设计 这样就使得开发人员和设计人员之间的协作更通畅 也极大地发挥了他们的专长 XAML 的发音为 Zamel 虽然 XAML 包含了许多新规则 元素和语法 但是我并不认为学习它是一个折磨人的过程 只要读者稍微具备一些 HTML 基础知识 就可以快速地掌握 XAML 中的大部分内容

    2025年8月19日
    4
  • redis:Could not connect to Redis at 127.0.0.1:6379: Connection refused错误解析「建议收藏」

    redis:Could not connect to Redis at 127.0.0.1:6379: Connection refused错误解析「建议收藏」1.错误信息思考:根据错误信息的字面意思,可以知道,redis-cli客户端程序,通过ip127.0.0.1,端口6379与redis服务器建立连接失败。说明当我们调用redis-cli时,默认是用本地回环地址去与服务器端建立连接。2.解决问题思路:服务器程序会在监听一个套接字(IP+端口号),等待客户端的连接。一般运行服务器程序的时候,都会加载一个配置文件。redis服务器也会读取一个配置文件。如果不知道配置文件在哪里,可以使用:whichredis.conf#或者whe

    2022年5月2日
    116
  • 黑苹果MacOS Big Sur 11.0 安装教程及驱动工具

    黑苹果MacOS Big Sur 11.0 安装教程及驱动工具最新黑苹果MacOSBigSur11.0安装教程,附带各电脑EFI驱动合集、原版引导镜像,图文并茂简单易懂…一、准备工作1.一个8G以上的U盘(安装10.15Catalina必须要16G及以上的U盘);2.MacOS镜像、TransMac(刻录工具)、DiskGenius(分区工具)、EasyUEFI(引导工区)、EFI驱动文件。安装工具获取链接:https://pan.baidu.com/s/1pwUVVo1Ud4yxO29k_ckTBw提取码:qs05安装镜像

    2022年6月3日
    159
  • php libpng 不兼容,Python matplotlib和libpng不兼容issu

    php libpng 不兼容,Python matplotlib和libpng不兼容issu我真的受这个问题困扰了这么久 最初 在用 matplotlib 绘制一些东西之后 我可以轻松地保存图像 但是 在安装了 scipy 之后 我再也无法保存我的图像了 我使用 pip 安装了 matplot 和 scipy 我试图查找一些信息 但还是无法解决问题 我的操作系统是 MacOSXLion 10 7 我认为以下链接是一些相关的问题似乎如果我可以重新链接库或设置 DYLD LIBRARY PATH 实际上

    2025年6月15日
    5
  • Jenkins详细安装与构建部署使用教程[通俗易懂]

    Jenkins详细安装与构建部署使用教程[通俗易懂]     Jenkins是一个开源软件项目,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。Jenkins是基于Java开发的一种持续集成工具,用于监控持续重复的工作,功能包括:1、持续的软件版本发布/测试项目。2、监控外部调用执行的工作。本文使用的Linux:Ubuntu其中JDK、Tomcat、SVN服务器请看这里Ubuntu安装配置JDK、Tomcat、SVN…

    2022年5月14日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号