RocketMQ 介绍

MQ 介绍

定义

  • MQ(Message Queue,消息队列)是一种用来保存消息数据的队列。

  • 队列:数据结构的一种,特征为“先进先出”。

MQ 作用

  • 应用解耦(技术上必须弄好才能使用 MQ)

  • 快速应用变更维护

  • 流量削锋(削峰填谷)

MQ 缺点

  • 系统可用性降低(解决:搭集群)
  • 系统复杂度提高(解决:程序员提升水平)
  • 异步消息机制(以下都有解决方案)
    • 消息时序性
    • 消息丢失
    • 消息一致性
    • 消息重复使用

MQ 常见产品

  • ActiveMQ :java 语言实现,万级数据吞吐量,处理速度 ms 级,主从架构,成熟度高。
  • RabbitMQ :erlang 语言实现,万级数据吞吐量,处理速度 us 级,主从架构。
  • RocketMQjava 语言实现,十万级数据吞吐量,处理速度 ms 级,分布式架构,功能强大,扩展性强
  • kafka :scala 语言实现,十万级数据吞吐量,处理速度 ms 级,分布式架构,功能较少,应用于大数据较多。

RocketMQ 简介

RocketMQ 是阿里开源的一款非常优秀中间件产品,脱胎于阿里的另一款队列技术 MetaQ,后捐赠给 Apache 基金会作为一款孵化技术,仅仅经历了一年多的时间就成为 Apache 基金会的顶级项目。并且现在已经在阿里内部被广泛应用,且经受住了多次双十一的这种极致场景的压力(2017 年的双十一,RocketMQ 流转的消息量达到了万亿级,峰值 TPS 达到 5600 万)。

同时,它还解决了上述提到的所有的消息队列的缺点。

RocketMQ 架构

RocketMQ 安装

1)安装 JDK

2)解压 RocketMQ 安装包下载地址):unzip rocketmq-all-4.5.2-bin-release.zip

3)修改目录名称:mv rocketmq-all-4.5.2-bin-release rocketmq

4)调整 RocketMQ 的启动内存

  • RocketMQ 的默认内存占用非常高,一般需要 4-8G 的虚拟机 JVM 参数空间,因此可以通过更改 mqbroker 和 mqnamesrv 的配置来调整内存。

  • RocketMQ 有两个启动脚本:bin 目录下的 runbroker.sh 和 runserver.sh,编辑如下内容,然后重新启动 broker 。

# vi runserver.sh
JAVA_OPT=”${JAVA_OPT} -server -Xms128m -Xmx128m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m” # vi runbroker.sh
JAVA_OPT=”${JAVA_OPT} -server -Xms128m -Xmx128m -Xmn125m
  • mqbroker 和 mqnamesrv 的内存也可以调整,这两项配置也很重要,默认是 500m 到 1g 。具体文件配置是 mqbroker.xml 和mqnamesrv.xml(文件里面的配置信息根据自己的情况修改):
<options>
<-Xms200m></-Xms200m>
<-Xmx200m></-Xmx200m>
<-XX:NewSize>50M</-XX:NewSize>
<-XX:MaxNewSize>50M</-XX:MaxNewSize>
<-XX:PermSize>30M</-XX:PermSize>
<-XX:MaxPermSize>30M</-XX:MaxPermSize>
</options>
  • 注意:mqbroker.xml 和 mqnamesrv.xml 的内存不要超过 runbroker.sh 和runserver.sh 的内存,不然会因为内存不够导致崩溃。

5)bin 目录下启动 NameServer 服务

sh mqnamesrv
# 后台启动
nohup sh mqnamesrv &
# 可以在当前目录的 nohup.out 中查看日志输出

6)bin 目录下启动 Borker 服务

sh mqbroker -n localhost:9876
# 后台启动
nohup sh mqbroker -n localhost:9876 &
# 指定配置文件
sh mqbroker -n localhost:9876 -c ../conf/broker.conf
# 可以在当前目录的 nohup.out 中查看日志输出

7)关闭防火墙

# 暂时关闭防火墙
systemctl stop firewalld # 永久设置防火墙状态
systemctl enable firewalld.service # 打开
systemctl disable firewalld.service # 关闭

8)测试

export NAMESRV_ADDR=localhost:9876
sh tools.sh org.apache.rocketmq.example.quickstart.Producer
sh tools.sh org.apache.rocketmq.example.quickstart.Consumer

最新文章

  1. Oracle Database 11g Express Editon介绍及安装
  2. php变量和数组大小限制
  3. 使用UltraISO制作U盘启动盘——转载
  4. BZOJ1012 [JSOI2008]最大数maxnumber
  5. UIlabel 属性text
  6. zw版【转发&#183;台湾nvp系列Delphi例程】HALCON SelectObj
  7. CSS3_边框属性之圆角
  8. ASPxCallback控件
  9. Android WebRTC 音视频开发总结(五)-- webrtc开发原型
  10. IP地址分类及私网IP
  11. Centos6.4配置Fedora EPEL源附配置hop5.in源
  12. Java使用反射机制优化工厂方法
  13. java异常的一些小知识
  14. (翻译)使用Api分析器与Windows兼容包来编写智能的跨平台.NET Core应用
  15. SpringCache与redis集成,优雅的缓存解决方案
  16. Spark入门(1-1)什么是spark,spark和hadoop
  17. C#:System.Array简单使用
  18. SVN-Failed to run the WC DB work queue associated with
  19. VSCode 启动 Vue 项目 npm install 报错
  20. 《AngularJS开发下一代Web应用》读书笔记与感想

热门文章

  1. [BSidesCF 2019]Runit(细心)
  2. mrctf2020_shellcode_revenge(可见符shellcode)!!!!
  3. [HarekazeCTF2019]baby_rop
  4. 2020ACTF pwn writeup
  5. C# ASP.NET WebApi 跨域设置
  6. Table.ReplaceValue替换…Replace…(Power Query 之 M 语言)
  7. 【译】使用 Visual Studio 调试外部源代码
  8. java面向对象类的继承~ 匿名类 ;多态特性;强制类型转换
  9. 音视频中的PTS和DTS及同步
  10. java.lang.StackOverflowError报错