`
boy00fly
  • 浏览: 194619 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

JMS简介与ActiveMQ实战

    博客分类:
  • J2EE
阅读更多

1. JMS架构

 

Java 消息服务(Java Message Service,简称JMS)是用于访问企业消息系统的开发商中立的API。企业消息系统可以协助应用软件通过网络进行消息交互。JMS 在其中扮演的角色与JDBC 很相似,正如JDBC 提供了一套用于访问各种不同关系数据库的公共APIJMS 也提供了独立于特定厂商的企业消息系统访问方式。

使用JMS 的应用程序被称为JMS 客户端,处理消息路由与传递的消息系统被称为JMS Provider,而JMS 应用则是由多个JMS 客户端和一个JMS Provider 构成的业务系统。发送消息的JMS 客户端被称为生产者(producer),而接收消息的JMS 客户端则被称为消费者(consumer)。同一JMS 客户端既可以是生产者也可以是消费者。

JMS 的编程过程很简单,概括为:应用程序A 发送一条消息到消息服务器(也就是JMS Provider)的某个目得地(Destination),然后消息服务器把消息转发给应用程序B。因为应用程序A 和应用程序B 没有直接的代码关连,所以两者实现了解偶。如下图:


 

消息传递系统的中心就是消息。一条Message 由三个部分组成:

 

消息的组成

 

1. (head)

每条JMS 消息都必须具有消息头。头字段包含用于路由和识别消息的值。可以通过多种方式来设置消息头的值:

a. 由JMS 提供者在生成或传送消息的过程中自动设置

b. 由生产者客户机通过在创建消息生产者时指定的设置进行设置

c. 由生产者客户机逐一对各条消息进行设置

 

2. 属性(property)

消息可以包含称作属性的可选头字段。他们是以属性名和属性值对的形式制定的。可以将属性是为消息头得扩展,其中可以包括如下信息:创建数据的进程、数据的创建时间以及每条数据的结构。JMS提供者也可以添加影响消息处理的属性,如是否应压缩消息或如何在消息生命周期结束时废弃消息。

 

3. 主体(body)

包含要发送给接收应用程序的内容。每个消息接口特定于它所支持的内容类型。JMS为不同类型的内容提供了他们各自的消息类型,但是所有消息都派生自Message接口。

StreamMessage   一种主体中包含Java基元值流的消息。其填充和读取均按顺序进行。

MapMessage     一种主体中包含一组键--值对的消息。没有定义条目顺序。

TextMessage       一种主体中包含Java字符串的消息(例如,XML消息)。

ObjectMessage    一种主体中包含序列化Java对象的消息。

BytesMessage     一种主体中包含连续字节流的消息。

例如:MapMessage 消息格式

 

MapMessage={
    Header={
        ... standard headers ...
        CorrelationID={123-00001}
    }
    Properties={
        AccountID={Integer:1234}
    }
    Fields={
        Name={String:Mark}
        Age={Integer:47}
    } 
}

 

消息的传递模型

 

JMS支持两种消息传递模型:点对点(point-to-point,简称PTP)和发布/订阅(publish/subscribe,简称pub/sub)。这两种消息传递模型非常相似,但有以下区别:

a. PTP消息传递模型规定了一条消息之恩能够传递费一个接收方。

b. Pub/sub消息传递模型允许一条消息传递给多个接收方

每个模型都通过扩展公用基类来实现。例如:javax.jms.Queue和Javax.jms.Topic都扩展自javax.jms.Destination类。

 

1. 点对点消息传递

通过点对点的消息传递模型,一个应用程序可以向另外一个应用程序发送消息。在此传递模型中,目标类型时队列。消息首先被传送至队列目标,然后从改对垒将消息传送至对此队列进行监听的某个消费者,如下图:

 

一个队列可以关联多个队列发送方和接收方,但一条消息仅传递给一个接收方。如果多个接收方正在监听队列上的消息,JMS Provider将根据“先来者优先”的原则确定由哪个价售房接受下一条消息。如果没有接收方在监听队列,消息将保留在队列中,直至接收方连接到队列为止。这种消息传递模型是传统意义上的拉模型或轮询模型。在此列模型中,消息不时自动推动给客户端的,而是要由客户端从队列中请求获得

 

2. 发布/订阅消息传递

通过发布/订阅消息传递模型,应用程序能够将一条消息发送到多个接收方。在此传送模型中,目标类型是主题。消息首先被传送至主题目标,然后传送至所有已订阅此主题的或送消费者。如下图:

 

主题目标也支持长期订阅。长期订阅表示消费者已注册了主题目标,但在消息到达目标时改消费者可以处于非活动状态。当消费者再次处于活动状态时,将会接收该消息。如果消费者均没有注册某个主题目标,该主题只保留注册了长期订阅的非活动消费者的消息。与PTP消息传递模型不同,pub/sub消息传递模型允许多个主题订阅者接收同一条消息。JMS一直保留消息,直至所有主题订阅者都接收到消息为止。pub/sub消息传递模型基本上时一个推模型。在该模型中,消息会自动广播,消费者无须通过主动请求或轮询主题的方法来获得新的消息。

 

上面两种消息传递模型里,我们都需要定义消息生产者和消费者,生产者吧消息发送到JMS Provider的某个目标地址(Destination),消息从该目标地址传送至消费者。消费者可以同步或异步接收消息,一般而言,异步消息消费者的执行和伸缩性都优于同步消息接收者,体现在:

1. 异步消息接收者创建的网络流量比较小。单向对东消息,并使之通过管道进入消息监听器。管道操作支持将多条消息聚合为一个网络调用。

2. 异步消息接收者使用线程比较少。异步消息接收者在不活动期间不使用线程。同步消息接收者在接收调用期间内使用线程,结果线程可能会长时间保持空闲,尤其是如果该调用中指定了阻塞超时。

3.对于服务器上运行的应用程序代码,使用异步消息接收者几乎总是最佳选择,尤其是通过消息驱动Bean。使用异步消息接收者可以防止应用程序代码在服务器上执行阻塞操作。而阻塞操作会是服务器端线程空闲,甚至会导致死锁。阻塞操作使用所有线程时则发生死锁。如果没有空余的线程可以处理阻塞操作自身解锁所需的操作,这该操作永远无法停止阻塞。

 

 

2. JMS Provider(ActiveMQ)

 

特性及优势

 

1. 实现JMS1.1规范,支持J2EE1.4以上。

2. 可运行与任何JVM和大部分web容器(ActiveMQ works great in any JVM)

3. 支持多种语言客户端(java, C, C++, Ajax, ActionScript等等)

4. 支持多种协议(stomp, openwire, REST)

5. 良好的Spring支持(ActiveMQ has great Spring Support)

6. 速度很快,JBossMQ的十倍(ActiveMQ is very fast; often 10x faster than JBossMQ)

7. 与OpenJMS、JBossMQ等开源jms provider相比,ActiveMQ有apache的支持,持续发展的优势明显

 

Queue与Topic的比较

 

1. JMS Queue执行load balancer语义

    一条消息仅能被一个consumer收到。如果在message发送的时候没有可用的consumer,那么它讲被保存一直到能处理该message的consumer可用。如果一个consumer收到一条message后却不响应它,那么这条消息将被转到另外一个consumer那儿。一个Queue可以有很多consumer,并且在多个可用的consumer中负载均衡。

 

2. Topic实现publish和subscribe语义

    一条消息被publish时,他将发送给所有感兴趣的订阅者,所以零到多个subscriber将接收到消息的一个拷贝。但是在消息代理接收到消息时,只有激活订阅的subscriber能够获得消息的一个拷贝。

 

3. 分别对应两种消息模式

    Point-to-Point(点对点),Publisher/Subscriber Model(发布/订阅者)

    其中在Publicher/Subscriber模式下又有Nondurable subscription(非持久化订阅)和durable subscription(持久化订阅)两种消息处理方式。

 

Point-to-Point(点对点)消息模式开发流程

 

1. 生产者(producer)开发流程

 

    1.1 创建 Connection

// 根据url,user和password创建一个jms Connection。
ActiveMQConnectionFactory connectionFactory   =   new ActiveMQConnectionFactory (user, password, url);
connection = connectionFactory.createConnection();
connection.start();

 

    1.2 创建Session

/**在connection的基础上创建一个session,同时设置是否支持事务ACKNOWLEDGE标识。
• AUTO_ACKNOWLEDGE:自动确认模式。一旦接收方应用程序的方法调用从处理消息处返回,会话对象就会确认消息的接收。 
• CLIENT_ACKNOWLEDGE:客户端确认模式。会话对象依赖于应用程序对被接收的消息调用一个acknowledge()方法。一旦这个方法被调用,会话会确认最后一次确认之后所有接收到的消息。这种模式允许应用程序以一个调用来接收,处理并确认一批消息。注意:在管理控制台中,如果连接工厂的Acknowledge Policy(确认方针)属性被设置为"Previous"(提前),但是你希望为一个给定的会话确认所有接收到的消息,那么就用最后一条消息来调用acknowledge()方法。 
• DUPS_OK_ACKNOWLEDGE:允许副本的确认模式。一旦接收方应用程序的方法调用从处理消息处返回,会话对象就会确认消息的接收;而且允许重复确认。在需要考虑资源使用时,这种模式非常有效。注意:如果你的应用程序无法处理重复的消息的话,你应该避免使用这种模式。如果发送消息的初始化尝试失败,那么重复的消息可以被重新发送。
•  SESSION_TRANSACTED**/
Session session = connection.createSession(
transacted, Session.AUTO_ACKNOWLEDGE);

 

    1.3 创建Destination对象

//需指定其对应的主题(subject)名称,producer和consumer将根据subject来发送/接收对应的消息
if (topic) {
	destination = session.createTopic(subject);
} else {
	destination = session.createQueue(subject);
}

 

    1.4 创建MessageProducer

//根据Destination创建MessageProducer对象,同时设置其持久模式。 
MessageProducer producer = session.createProducer(destination);
if (persistent) {
      producer.setDeliveryMode(DeliveryMode.PERSISTENT);
} else {
      producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
}
if (timeToLive != 0) {
       producer.setTimeToLive(timeToLive);
} 

 

    1.5 发送消息到队列(Queue)

//封装TextMessage消息,使用MessageProducer的send方法将消息发送出去。
TextMessage message = session.createTextMessage("createMessageText");
producer.send(message);

 

2. 消费者(consumer)开发流程

 

    2.1 实现MessageListener接口

//消费者类必须实现MessageListener接口,然后在onMessage方法中监听消息到达处理。

 

    2.2 创建Connection

//根据url,user和password创建一个jms Connection,如果是durable模式,还需要给connection设置一个clientId。
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(user, password, url);
Connection connection = connectionFactory.createConnection();
if (durable && clientId != null && clientId.length() > 0 && !"null".equals(clientId)) {
      connection.setClientID(clientId);
}
connection.setExceptionListener(this);
connection.start();

 

    2.3 创建Session和Destination

//与产品类似

 

    2.4 创建replayProducer【可选】

//可以用来将消息处理结果发送给producer。 
replyProducer = session.createProducer(null);
replyProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT); 

 

    2.5 创建MessageConsumer

//根据Destination创建MessageConsumer对象。
MessageConsumer consumer = null;
if (durable && topic) {
     consumer = session.createDurableSubscriber((Topic)destination, consumerName);
} else {
     consumer = session.createConsumer(destination);
} 

 

    2.6 消费message

//在onMessage()方法中接收producer发送过来的消息进行处理,并可以通过replyProducer反馈信息给producer 
if (message.getJMSReplyTo() != null) { 
	replyProducer.send(message.getJMSReplyTo(), 
	session.createTextMessage("Reply: " + message.getJMSMessageID())); 
}  

 

 

Publish/Subscriber(发布/订阅者)消息开发模式

 

1. 订阅者(Subscriber)开发流程

 

    1.1 实现MessageListener接口

  在onMessage()方法中监听发布者发出的消息队列,并做相应处理。

 

    1.2 创建Connection

          根据url, user和password创建一个jms connection

 

    1.3 创建Session

  在connection的基础上创建一个session,同时设置是否支持和ACKNOWLEDGE标志。

 

    1.4 创建 Topic

          创建两个Topic,topictest.message用于接收发布者发出的消息,topictest.control用于向发布者发送消息,实现双方的交互。

 

    1.5 创建consumer和producer对象

  根据topictest.message创建consumer,根据topictest.control创建producer

 

    1.6 接收处理消息

  在onMessage()方法中,对收到的消息进行处理,可直接简单在本地显示消息,或者根据消息内容不同处理对应的业务逻辑(比如:数据库更新、文件操作等等),并且可以使用   producer对象处理结果返回给发布者。

 

 

2. 发布者(Publisher)开发流程

 

     2.1 实现MessageListener接口 

   在onMessage()方法中接收订阅者的反馈消息。

 

     2.2 创建Connection

   根据url, user和password 创建一个 jms Connection。

 

     2.3 创建session

   在connection的基础上创建一个session,同时设置是否支持事务和ACKNOWLEDGE标志。

 

     2.4 创建Topic

   创建两个Topic,topictest.messages用于向订阅者发布消息,topictest.control用于接收订阅者反馈的消息。这两个Topic与订阅者开发流程中的topic是一一对应的。

 

     2.5 创建consumer和producer对象

   根据topictest.message创建publisher;

   根据topictest.control穿件consumer,同时监听订阅者反馈的消息。

 

3. JMS For Spring

 

      Spring提供了用于简化JMS API使用的抽象框架,并且对用户屏蔽了JMS API中1.0.2和1.1版本的差异。

      JMS的功能大致上分为两块,叫做消息制造和消息消耗。JmsTemplate用于制造消息和同步消息接收。和J2EE的事件驱动Bean风格类似,对于异步接收消息,Spring提供了一些消息监听容器来创建消息驱动的POJO(MDP)。

 

1. Spring 配置 connectionFactory

<!--客户端使用普通传输方式:tcp://localhost:61616 
	此处需加以注意的是Listener端的borkerURL使用了failover传输方式: 
	failover:(tcp://localhost:61616)?initialReconnectDelay=100&amp;
maxReconnectAttempts=5 
	failover transport是一种重新连接机制,用于建立可靠的传输。此处配置的是一旦ActiveMQ broker中断,Listener端将每隔100ms自动尝试连接,直至成功连接或重试5次连接失败为止。
	failover还支持多个borker同时提供服务,实现负载均衡的同时可增加系统容错性,格式: failover:(uri1,...,uriN)?transportOptions
-->
<bean id="jmsFactory" destroy-method="stop" class="org.apache.activemq.pool.PooledConnectionFactory">
		<property name="connectionFactory">
			<bean class="org.apache.activemq.ActiveMQConnectionFactory">
				<property name="brokerURL" value="tcp://localhost:61616" />
                 <property name="userName" value="${activemq.username}" />
				<property name="password" value="${activemq.password}" />
			</bean>
		</property>
</bean>
  

2. Spring JmsTemplate

<!-- Spring JMS Template
		JmsTemplate 类的实例 一经配置便是线程安全 的。 要清楚一点,JmsTemplate 
		是有状态的,因为它维护了 ConnectionFactory 的引用,但这个状态时不是会话状态。
-->
	<bean id="myJmsTemplate"
		class="org.springframework.jms.core.JmsTemplate">
		<property name="connectionFactory" ref="jmsFactory" />
		<property name="defaultDestinationName" value="MySubject" />
		<!--JMS API有两种发送方法,一种采用发送模式、
优先级和存活时间作为服务质量(QOS)参数,
			默认{deliveryMode:2(1),priority:4,timeToLive:0}
			另一种使用无需QOS参数的缺省值方法。
			<property name="explicitQosEnabled" value="true"/>
			<property name="deliveryMode" value="2"/>
			<property name="priority" value="4"/>
                        <property name="timeToLive" value="1000"/>
		 -->
		<!--
		 	<property name="receiveTimeout" value="1000" />
		 -->
	</bean>
  

3. 发送的接收消息

<bean id="destinationTopic"
		class="org.apache.activemq.command.ActiveMQTopic">
		<constructor-arg index="0" value="HelloWorldTopic" />
	</bean>
	<!-- 读取信息 -->
	<bean id="consumer" class="com.d1xn.jms.demo.Consumer">
		<property name="jmsTemplate" ref="myJmsTemplate" />
	</bean>

	<!-- 发送信息 -->
	<bean id="producerTopic" class="com.d1xn.jms.demo.ProducerTopic">
		<property name="jmsTemplet" ref="myJmsTemplate" />
		<property name="destination" ref="destinationTopic" />
	</bean>
	<!-- 消息监听 -->

	<bean id="listenerContainerTopic"
class="org.springframework.jms.listener.DefaultMessageListenerContainer">
		<property name="connectionFactory" ref="jmsFactory" />
		<property name="destination" ref="destinationTopic" />
		<property name="messageListener" ref="consumer" />
         <!—持久化客户端ID -->
		<property name="clientId" value="clientId_001" />
		<property name="subscriptionDurable" value="true" />
		<property name="durableSubscriptionName" value="My_001" />
</bean>

 

 

说明(基于ActiveMQ5.4.2版本):

        1、Web Console 的安全配置可参考      

 

    将conf/jetty.xml下面一段xml配置:

 

<bean id="securityConstraint" class="org.eclipse.jetty.http.security.Constraint">
    <property name="name" value="BASIC" />                                       
    <property name="roles" value="admin" />                                      
    <property name="authenticate" value="true" />                                
</bean>                                                                          

 

   authenticate值设置为true即可!那用户名/密码的配置是在conf/jetty-realm.properties!

   详细可参考http://activemq.apache.org/web-console.html

 

2、连接安全配置可参考

     将conf/activemq-security.xml中如下的配置

<plugins>    		                                                                               
 <!-- Configure authentication; Username, passwords and groups -->                             
 <simpleAuthenticationPlugin anonymousAccessAllowed="false">                                   
    <users>                                                                                    
        <authenticationUser username="system" password="${activemq.password}"                  
            groups="admins"/>                                                                  
        <!--<authenticationUser username="user" password="${guest.password}"                   
            groups="users"/>                                                                   
        <authenticationUser username="guest" password="${guest.password}" groups="guests"/>--> 
    </users>                                                                                   
 </simpleAuthenticationPlugin>                                                                 
</plugins>                                                                                     

            copy至conf/activemq.xml中

<persistenceAdapter>                                  
    <kahaDB directory="${activemq.base}/data/kahadb"/>
</persistenceAdapter>                                 

      的下面(这是简单的用户名、密码的认证方式)!

   用户名、密码的可在conf/credentials.properties配置!

   详细可参考:

     http://activemq.apache.org/security.html

     http://activemq.apache.org/xml-reference.html

  • 大小: 12.9 KB
  • 大小: 24.7 KB
  • 大小: 25.8 KB
分享到:
评论
10 楼 hahalzb 2018-02-23  
请问文件解压缩的密码是什么呀
9 楼 ershimengx 2018-01-22  
JMS&ActiveMQ实战(JMS+ActiveMQ+Drools)
网盘地址:https://pan.baidu.com/s/1qZ6O3Ic 密码: qc6y
网盘地址:https://pan.baidu.com/s/1pMjjXj1 密码: xk9e
8 楼 P00116 2017-09-05  
7 楼 风会停息丶 2017-06-13  
你好,下载完成后解压密码是多少,跟网盘下载密码一样吗
6 楼 Yolanda_NuoNuo 2017-03-21  
请问文件解压缩的密码是什么呀
5 楼 360pluse 2016-11-14  
JMS&ActiveMQ实战(JMS+ActiveMQ+Drools)
网盘地址:http://pan.baidu.com/s/1geIXZ8n 密码:fbqg

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

01.1_JMS&ActiveMQ介绍
01.2_JMS&ActiveMQ介绍
01.3_JMS&ActiveMQ介绍
02.1_JMS消息模型
02.2_JMS消息模型
02.3_JMS消息模型
02.4_JMS消息模型
03.1_JMS消息剖析
03.2_JMS消息剖析
03.3_JMS消息剖析
04.1_JMS高级特性
04.2_JMS高级特性
04.3_JMS高级特性
04.4_JMS高级特性
04.5_JMS高级特性
04.6_JMS高级特性
04.7_JMS高级特性
05.1_Spring集成JMS
05.2_Spring集成JMS
06.1_JMS应用案例
06.2_JMS应用案例
06.3_JMS应用案例
07.1_MQ传输器&传输协议
07.2_MQ传输器&传输协议
07.3_MQ传输器&传输协议
07.4_MQ传输器&传输协议
08.1_MQ消息存储
08.2_MQ消息存储
08.3_MQ消息存储
08.4_MQ消息存储
09.1_MQ安全机制
09.2_MQ安全机制
09.3_MQ安全机制
10.1_MQ集群技术
10.2_MQ集群技术
10.3_MQ集群技术
11.1_MQ高级特性
11.2_MQ高级特性
11.3_MQ高级特性
11.4_MQ高级特性
12.1_MQ性能调优
12.2_MQ性能调优
12.3_MQ性能调优
13.1_MQ监控与管理
13.2_MQ监控与管理
13.3_MQ监控与管理
14.1_基于事件驱动案例-规则引擎
14.2_基于事件驱动案例-规则引擎
14.3_基于事件驱动案例-规则引擎
15.1_基于事件驱动案例-业务需求
15.2_基于事件驱动案例-业务需求
15.3_基于事件驱动案例-业务需求
16.1_基于事件驱动案例-数据采集
16.2_基于事件驱动案例-数据采集
17.1_基于事件驱动案例-监控规则任务
17.2_基于事件驱动案例-监控规则任务
17.3_基于事件驱动案例-监控规则任务
4 楼 huanjueshacha 2015-11-26  
楼主您好,我试了一下activemq的发布-订阅模式,
我设置的持久化是持久化到mysql里面
发布者publisher发完消息,设置了两个订阅者subscriber,
都消费完了消息,但是消息还在mysql中,
这个是永远都会存在持久化里面么?

之前我试了点对点模式
Queue里面的消息先持久化到数据库中,
消费者拿到消息后,数据库中的消息就直接被删除了。
所以我比较困惑为什么发布-订阅模式数据库中的消息没有被删除,
希望楼主能教我一下。
3 楼 xiaopeng187 2013-12-27  
请问一下使用MessageListener接口的方式来消费消息时 怎么控制消费的速度。我想实现的是消费一个后,处理完以后再去消费下一个,但是每次都是一次都把所用的消费完了?麻烦你了
2 楼 boy00fly 2012-03-13  
maishj 写道
请教下实际项目中,是用代码来启动broker还是直接运行bin目录下的activemq.bat文件

直接启动就可以了
1 楼 maishj 2012-03-13  
请教下实际项目中,是用代码来启动broker还是直接运行bin目录下的activemq.bat文件

相关推荐

    JMS简介与ActiveMQ实战代码分享

    主要介绍了JMS简介与ActiveMQ实战代码分享,具有一定借鉴价值,需要的朋友可以参考下

    ActiveMQ 实战

    ActiveMQ 实战。本手册介绍了JMS以及ActiveMQ的常用操作以及配置。可以作为ActiveMQ应用开发人员的参考手册。

    ActiveMQ实战资料

    含如下内容:JMS API;Apache-activeMQ;ActiveMQ实战pdf

    ACTIVEMQ实战 部分翻译(1——4.3)

    ACTIVEMQ实战部分翻译,只翻译了第一章到第四章的第三节

    实战ActiveMQ集群与应用视频教程.zip

    1:ActiveMQ入门和消息中间件 2:JMS基本概念和模型 3:JMS的可靠性机制 4:JMS的API结构和开发步骤 5:Broker的启动方式 6:ActiveMQ结合Spring开发 7:ActiveMQ支持的传输协议 8:ActiveMQ消息存储持久化 9:...

    ActiveMQ.txt

    【ActiveMQ】—01—实战ActiveMQ集群与应用.消息队列中间件ActiveMQ入门到精通视频教程及资料一头扎进JMS之ActiveMQ视频教程.

    项目实战:ActiveMQ开发大型分布式系统

    消息中间件是搭建大型企业级项目必不可少的成员,只有掌握了消息中间件的使用和应用场景,才能开发真正的大型分布式系统。ActiveMQ支持JMS,是apache的顶级项目,在全球开源消息中间件中影响力大!

    全新JAVAEE大神完美就业实战课程 超150G巨制课程轻松实战JAVAEE课程 就业部分.txt

    day08_activeMQ介绍_搭建_解决同步索引库问题 day09_FreeMark入门_静态化页面标签介绍_静态化页面实现 day10_Nginx代理详解..单点登录系统工程搭建_接口文档讲解 day11_单点登录系统实现_用户名回显_cookie跨域...

    2小时学会Spring+Dubbo整合ActiveMQ消息队列

    在职开发人员学完后会让你的薪资更高,让你更了解互联网是如何解决高并发 学完SSM框架的同学就可以学习,能让你切身感受到企业级开发环境目标1:理解消息中间件、JMS等概念目标2:掌握JMS点对点与发布订阅模式的收发...

    2019品优购.txt

    前端:angularJS + Bootstrap 后台:SSM( springmvc+spring+mybatis) 数据库:mysql,使用mycat读写分离 开发模式:SOA 服务中间件:dubbox,需要和zookeeper配合使用 注册中心:zookeeper 消息中间件:Activemq,...

    单点登录源码

    ActiveMQ | 消息队列 | [http://activemq.apache.org/](http://activemq.apache.org/) JStorm | 实时流式计算框架 | [http://jstorm.io/](http://jstorm.io/) FastDFS | 分布式文件系统 | ...

Global site tag (gtag.js) - Google Analytics