消息队列-RocketMQ
2021/6/22 6:28:29
本文主要是介绍消息队列-RocketMQ,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一.概述
- 大多数应用中,都可以通过消息服务中间件的方式来提升系统的异步通信、扩展解耦能力
- 消息服务中两个重要的概念:消息代理(Message broker)和目的地(destination),当消息发送者发送消息之后,将有消息代理接管,消息代理保证消息传递到指定的目的地。
- 消息队列主要由两种形式的目的地,队列(queue):点对点消息通信;主题(topic):发布(publish)和订阅(subscribe)消息通信。
二.RocketMQ
1、RocketMQ简介
RocketMQ是一个纯Java、分布式、队列模型的开源消息中间件,前身是MetaQ,是阿里参考Kafka特点研发的一个队列模型的消息中间件,后开源给apache基金会成为了apache的顶级开源项目,具有高性能、高可靠、高实时、分布式特点。
2、RocketMQ下载安装(windows和linux基本相同)
1.下载地址
https://github.com/apache/rocketmq/releases
2.环境要求
64bit OS, Linux/Unix/Mac is recommended;(Windows user see guide below) 64bit JDK 1.8+; Maven 3.2.x; Git; 4g+ free disk for Broker server
3.解压安装
进入主目录预编译
cd /rocketmq/rocketmq-rocketmq-all-4.9.0 mvn -Prelease-all -DskipTests clean install -U
需要下载的挺多的。
4.搬移
将maven解压打的包挪到常用路径下
cd /rocketmq/rocketmq-rocketmq-all-4.9.0/distribution/target/rocketmq-4.9.0 mv rocketmq-4.9.0/ /usr/local/
5.bin路径文件
-rwxr-xr-x 1 root root 1654 Jun 21 21:49 cachedog.sh -rwxr-xr-x 1 root root 845 Jun 21 21:49 cleancache.sh -rwxr-xr-x 1 root root 1116 Jun 21 21:49 cleancache.v1.sh drwxr-xr-x 2 root root 4096 Jun 21 21:49 dledger -rwxr-xr-x 1 root root 1400 Jun 21 21:49 mqadmin -rwxr-xr-x 1 root root 1029 Jun 21 21:49 mqadmin.cmd -rwxr-xr-x 1 root root 1394 Jun 21 21:49 mqbroker -rwxr-xr-x 1 root root 1084 Jun 21 21:49 mqbroker.cmd -rwxr-xr-x 1 root root 1373 Jun 21 21:49 mqbroker.numanode0 -rwxr-xr-x 1 root root 1373 Jun 21 21:49 mqbroker.numanode1 -rwxr-xr-x 1 root root 1373 Jun 21 21:49 mqbroker.numanode2 -rwxr-xr-x 1 root root 1373 Jun 21 21:49 mqbroker.numanode3 -rwxr-xr-x 1 root root 1396 Jun 21 21:49 mqnamesrv -rwxr-xr-x 1 root root 1088 Jun 21 21:49 mqnamesrv.cmd -rwxr-xr-x 1 root root 1571 Jun 21 21:49 mqshutdown -rwxr-xr-x 1 root root 1398 Jun 21 21:49 mqshutdown.cmd -rwxr-xr-x 1 root root 2222 Jun 21 21:49 os.sh -rwxr-xr-x 1 root root 1148 Jun 21 21:49 play.cmd -rwxr-xr-x 1 root root 1008 Jun 21 21:49 play.sh -rwxr-xr-x 1 root root 772 Jun 21 21:49 README.md -rwxr-xr-x 1 root root 2230 Jun 21 21:49 runbroker.cmd -rwxr-xr-x 1 root root 3734 Jun 21 21:49 runbroker.sh -rwxr-xr-x 1 root root 1840 Jun 21 21:49 runserver.cmd -rwxr-xr-x 1 root root 4048 Jun 21 21:49 runserver.sh -rwxr-xr-x 1 root root 1156 Jun 21 21:49 setcache.sh -rwxr-xr-x 1 root root 1408 Jun 21 21:49 startfsrv.sh -rwxr-xr-x 1 root root 1634 Jun 21 21:49 tools.cmd -rwxr-xr-x 1 root root 1903 Jun 21 21:49 tools.sh
6.启动
遇到问题:内存不足无法启动,修改runserver.sh配置文件
#JAVA_OPT="${JAVA_OPT} -server -Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m" JAVA_OPT="${JAVA_OPT} -server -Xms500m -Xmx500m -Xmn500m -XX:PermSize=128m -XX:MaxPermSize=320m"
启动nameserver
./mqnamesrv
启动mqbroker(同样要求改配置,这个默认的更大)
./mqbroker
7.测试
./tools.sh org.a[ache.rocketmq.example.quickstart.Producer
遇到异常1:发送失败提示
java.lang.IllegalStateException: org.apache.rocketmq.remoting.exception.RemotingConnectException: connect to null failed
在tools脚本中添加
export NAMESRV_ADDR=localhost:9876
遇到异常2:Broker没有连接到Server
No route info of this topic: TopicTest
重新启动broker,并且指定IP:端口
./mqbroker -n localhost:9876
8.rocketmq-externals
这篇关于消息队列-RocketMQ的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升