消息中间件ActiveMQ

消息中间件ActiveMQ

一、分布式系统架构

1.背景

随着互联网的快速发展和云服务概念的普及,使得我们在搭建系统的时候越来越倾向于分布式系统架构,那么分布式系统架构要涉及到哪些知识点以及我们如何来实现这个分布式系统架构。

2.Java项目的架构演变历程

单一的应用架构-->垂直应用架构-->分布式应用架构:

演变历程.png

①单一应用架构(传统的架构思维):
一个项目就是一个系统。

②垂直应用架构(一个系统拆分成多个子系统):
一定程度上解决了系统难以维护的问题,每个团队就负责自己的子系统,降低了维护成本,提升了开发效率。也解决了系统扩容的问题,随着业务的扩展,可以通过增加一个子系统来解决,不会影响其他子系统。同样也在一定程度上解决了系统访问进行分流的问题,根据子系统的不同性质和访问量进行合理的部署规划。但是垂直应用系统架构中各个子系统都存在着相同逻辑的业务代码(权限验证、日志记录、缓存、系统安全性、系统报表),不能共用,容易造成信息孤岛,重复造轮子。

③分布式架构(一个系统拆分成多个服务):
随着垂直应用架构的子系统越来越多,为了避免重复造轮子,我们将共用的核心业务抽取出来,作为单独的系统进行服务,各个子系统就可以重复调用,就演变成了分布式架构。架构一套大型的,成熟的分布式系统要涉及到许多中间件的应用和支撑系统,这些中间件和支撑统称为分布式系统的基础设施。

3.分布式系统的基础设施

①SpringBoot:微服务框架:简化配置,快速搭建开发框架
②Dubbo:分布式远程服务调用框架(RPC),与spring无缝集成
③ActiveMQ:支持JMS规范的分布式消息中间件。
④Zookeeper:分布式服务的配置和调度以及协调中心
⑤Redis:支持集群的内存数据库,可以快速的读取非结构化数据。
⑥Solr:垂直化搜索引擎,大型电商平台的站内搜索解决方案(基于lucene)
⑦Nginx:反向代理和负载均衡服务器
⑧Mysql:基于分布式系统的分库分表以及集群 mariaDB

二、消息中间件的定义和作用

消息中间件.png

消息中间件是在分布式系统中完成消息发送和接收的基础软件。通过消息中间件,应用程序之间可以进行可靠的异步通讯,从而降低系统的耦合度,提高系统的可扩展性和可用性。

应用程序A:消息生产者
应用程序B:消息消费者

1.JMS的概念

JMS(Java Message Server):即java消息服务,他是一套基于java平台关于消息服务的一套接口,主要用于两个或多个应用程序之间或者在分布式系统中间发送消息和接收消息,进行异步通信。
JMS是一套接口,各个厂商可以通过实现这套接口来实现JMS服务:ActiveMQ、RabbitMQ、RocketMQ

2.ActiveMQ

官方网站:http://activemq.apache.org

要求:jdk环境

启动:

启动activemq.png

访问:localhost:8161
默认用户名和密码:admin

三、实例

第一步:引入jar包:

引入jar包.png

代码:

JmsProducer:消息生产者


package com.hcx.activemq.p2p;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

/**
 * 定义消息的生产者
 * 
 * @author HCX
 *
 */
public class JmsProducer {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String BROKENURL = ActiveMQConnection.DEFAULT_BROKER_URL;

    /**
     * 定义消息并发送,等待消息的接收者(消费者)消费此消息
     * 
     * @param args
     * @throws JMSException
     */
    public static void main(String[] args) throws JMSException {
        ConnectionFactory connectionFactory;// 消息中间件的连接工厂
        Connection connection = null;// 连接
        Session session = null;// jms.Session;
        Destination destination;// 消息的目的地
        MessageProducer messageProducer = null;// 消息生产者

        // 实例化连接工厂,创建一个连接
        connectionFactory = new ActiveMQConnectionFactory(JmsProducer.USERNAME, JmsProducer.PASSWORD,
                JmsProducer.BROKENURL);
        // 通过连接工厂获取连接
        try {
            connection = connectionFactory.createConnection();

            // 启动连接
            connection.start();
            // 创建session,进行消息的发送
            session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

            // 创建消息队列
            destination = session.createQueue("talkWithMon");

            // 创建一个消息生产者
            messageProducer = session.createProducer(destination);

            // 模拟发送消息
            for (int i = 0; i < 5; i++) {
                // 创建一条消息
                TextMessage textMessage = session.createTextMessage("给妈妈发送的消息:" + i);
                System.out.println("textMessage: " + textMessage);
                messageProducer.send(textMessage);
            }

            // 如果设置了事务,session就必须要提交
            session.commit();
        } catch (JMSException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            // 关闭连接
            if (connection != null) {
                connection.close();
            }
        }
    }
}

JmsConsumer:消息消费者


package com.hcx.activemq.p2p;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

/**
 * 定义消息的消费者
 * 
 * @author HCX
 *
 */
public class JmsConsumer {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String BROKENURL = ActiveMQConnection.DEFAULT_BROKER_URL;

    
    public static void main(String[] args) throws JMSException {
        ConnectionFactory connectionFactory;// 消息中间件的连接工厂
        Connection connection = null;// 连接
        Session session = null;// jms.Session;
        Destination destination;// 消息的目的地
        MessageConsumer messageConsumer = null;// 消息消费者

        // 实例化连接工厂,创建一个连接
        connectionFactory = new ActiveMQConnectionFactory(JmsConsumer.USERNAME, JmsConsumer.PASSWORD,
                JmsConsumer.BROKENURL);
        // 通过连接工厂获取连接
        try {
            connection = connectionFactory.createConnection();

            // 启动连接
            connection.start();
            // 创建session,进行消息的接收
            session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

            // 创建消息队列 注意:队列的名字要相同
            destination = session.createQueue("talkWithMon");

            // 创建一个消息消费者
            messageConsumer = session.createConsumer(destination);

            // 模拟接收消息
            while (true) {
                TextMessage textMessage = (TextMessage) messageConsumer.receive(10000);
                if(null!=textMessage){
                    System.out.println("收到儿子发送的消息: "+textMessage);
                }else{
                    break;
                }
            }

        } catch (JMSException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } 
    }
}

结果:

消息队列.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,372评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,368评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,415评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,157评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,171评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,125评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,028评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,887评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,310评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,533评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,690评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,411评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,004评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,812评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,693评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,577评论 2 353

推荐阅读更多精彩内容

  • 中间件 非底层操作系统软件,非业务应用软件,不能直接给最终用户使用和带来价值的软件。 消息中间件 关注于数据的发送...
    wch853阅读 1,019评论 0 0
  • 消息中间件 消息中间件有很多的用途和优点: 1. 将数据从一个应用程序传送到另一个应用程序,或者从软件的一个模块传...
    错位的季节阅读 792评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,651评论 18 139
  • 消息中间件选型分析 有很多网友留言:公司要做消息中间件选型,该如何选?你觉得哪个比较好?消息选型的确是一个大论题,...
    消失er阅读 2,018评论 0 24
  • 经济学有个概念,叫“机会成本”。“机会成本”是指为了得到某种东西而所要放弃另一些东西的最大价值。简单打个比方,比方...
    劉楠阅读 531评论 0 0