出处:http://www.cnblogs.com/leiOOlei/p/5075402.html

一、配置部分

ActiveMQ的安装这就不说了,很简单,

这个例子采用maven构建,首先看一下pom.xml

 
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  3.  
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.gzframe.demo</groupId>
  6. <artifactId>gzframe</artifactId>
  7. <packaging>war</packaging>
  8. <version>0.0.1-SNAPSHOT</version>
  9. <name>gzframe Maven Webapp</name>
  10. <url>http://maven.apache.org</url>
  11.  
  12. <!-- 版本管理 -->
  13. <properties>
  14. <springframework>4.1.8.RELEASE</springframework>
  15. <javax.servlet>3.1.0</javax.servlet>
  16. </properties>
  17.  
  18. <dependencies>
  19.  
  20. <dependency>
  21. <groupId>junit</groupId>
  22. <artifactId>junit</artifactId>
  23. <version>4.10</version>
  24. <scope>test</scope>
  25. </dependency>
  26.  
  27. <dependency>
  28. <groupId>jstl</groupId>
  29. <artifactId>jstl</artifactId>
  30. <version>1.2</version>
  31. </dependency>
  32.  
  33. <dependency>
  34. <groupId>javax.servlet</groupId>
  35. <artifactId>servlet-api</artifactId>
  36. <version>${javax.servlet}</version>
  37. </dependency>
  38.  
  39. <!-- spring -->
  40. <dependency>
  41. <groupId>org.springframework</groupId>
  42. <artifactId>spring-core</artifactId>
  43. <version>${springframework}</version>
  44. </dependency>
  45. <dependency>
  46. <groupId>org.springframework</groupId>
  47. <artifactId>spring-context</artifactId>
  48. <version>${springframework}</version>
  49. </dependency>
  50. <dependency>
  51. <groupId>org.springframework</groupId>
  52. <artifactId>spring-tx</artifactId>
  53. <version>${springframework}</version>
  54. </dependency>
  55. <dependency>
  56. <groupId>org.springframework</groupId>
  57. <artifactId>spring-webmvc</artifactId>
  58. <version>${springframework}</version>
  59. </dependency>
  60. <dependency>
  61. <groupId>org.springframework</groupId>
  62. <artifactId>spring-jms</artifactId>
  63. <version>${springframework}</version>
  64. </dependency>
  65. <!-- xbean 如<amq:connectionFactory /> -->
  66. <dependency>
  67. <groupId>org.apache.xbean</groupId>
  68. <artifactId>xbean-spring</artifactId>
  69. <version>3.16</version>
  70. </dependency>
  71.  
  72. <!-- activemq -->
  73. <dependency>
  74. <groupId>org.apache.activemq</groupId>
  75. <artifactId>activemq-core</artifactId>
  76. <version>5.7.0</version>
  77. </dependency>
  78. <dependency>
  79. <groupId>org.apache.activemq</groupId>
  80. <artifactId>activemq-pool</artifactId>
  81. <version>5.12.1</version>
  82. </dependency>
  83.  
  84. </dependencies>
  85.  
  86. <build>
  87. <finalName>gzframe</finalName>
  88. </build>
  89. </project>
 

接下来看一下web.xml,如下

 
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://java.sun.com/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
  5. http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  6. version="3.0">
  7.  
  8. <display-name>Archetype Created Web Application</display-name>
  9.  
  10. <!-- 加载spring的配置文件,例如hibernate、jms等集成 -->
  11. <context-param>
  12. <param-name>contextConfigLocation</param-name>
  13. <param-value>
  14. classpath:spring-root.xml;
  15. classpath:activemq.xml;
  16. </param-value>
  17. </context-param>
  18.  
  19. <listener>
  20. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  21. </listener>
  22.  
  23. <servlet>
  24. <servlet-name>springMVC</servlet-name>
  25. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  26. <init-param>
  27. <param-name>contextConfigLocation</param-name>
  28. <param-value>classpath:spring-mvc-dispatch.xml</param-value>
  29. </init-param>
  30. <load-on-startup>1</load-on-startup>
  31. </servlet>
  32. <servlet-mapping>
  33. <servlet-name>springMVC</servlet-name>
  34. <url-pattern>/</url-pattern>
  35. </servlet-mapping>
  36.  
  37. <!-- 处理编码格式 -->
  38. <filter>
  39. <filter-name>characterEncodingFilter</filter-name>
  40. <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  41. <init-param>
  42. <param-name>encoding</param-name>
  43. <param-value>UTF-8</param-value>
  44. </init-param>
  45. <init-param>
  46. <param-name>forceEncoding</param-name>
  47. <param-value>true</param-value>
  48. </init-param>
  49. </filter>
  50. <filter-mapping>
  51. <filter-name>characterEncodingFilter</filter-name>
  52. <url-pattern>/*</url-pattern>
  53. </filter-mapping>
  54.  
  55. </web-app>
 

其中spring-root.xml 很简单,负责加载一些spring的配置

 
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-4.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
  12.  
  13. <context:component-scan base-package="com.gzframe.demo.entity" />
  14. <mvc:annotation-driven />
  15.  
  16. </beans>
 

spring-mvc-dispatch.xml如下

 
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-4.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
  12.  
  13. <context:component-scan base-package="com.gzframe.demo.mvc.controller" />
  14. <mvc:annotation-driven />
  15.  
  16. <bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver">
  17. <property name="viewClass"
  18. value="org.springframework.web.servlet.view.JstlView" />
  19. <property name="prefix" value="/WEB-INF/views/" />
  20. <property name="suffix" value=".jsp" />
  21. </bean>
  22. </beans>
 

activemq.xml是关键的配置,如下

 
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:amq="http://activemq.apache.org/schema/core"
  5. xmlns:jms="http://www.springframework.org/schema/jms"
  6. xmlns:context="http://www.springframework.org/schema/context"
  7. xmlns:mvc="http://www.springframework.org/schema/mvc"
  8. xsi:schemaLocation="
  9. http://www.springframework.org/schema/beans
  10. http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
  11. http://www.springframework.org/schema/context
  12. http://www.springframework.org/schema/context/spring-context-4.1.xsd
  13. http://www.springframework.org/schema/mvc
  14. http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
  15. http://www.springframework.org/schema/jms
  16. http://www.springframework.org/schema/jms/spring-jms-4.1.xsd
  17. http://activemq.apache.org/schema/core
  18. http://activemq.apache.org/schema/core/activemq-core-5.12.1.xsd"
  19. >
  20.  
  21. <context:component-scan base-package="com.gzframe.demo.activemq" />
  22. <mvc:annotation-driven />
  23.  
  24. <amq:connectionFactory id="amqConnectionFactory"
  25. brokerURL="tcp://192.168.150.61:61616"
  26. userName="admin"
  27. password="admin" />
  28.  
  29. <!-- 配置JMS连接工长 -->
  30. <bean id="connectionFactory"
  31. class="org.springframework.jms.connection.CachingConnectionFactory">
  32. <constructor-arg ref="amqConnectionFactory" />
  33. <property name="sessionCacheSize" value="100" />
  34. </bean>
  35.  
  36. <!-- 定义消息队列(Queue) -->
  37. <bean id="demoQueueDestination" class="org.apache.activemq.command.ActiveMQQueue">
  38. <!-- 设置消息队列的名字 -->
  39. <constructor-arg>
  40. <value>gzframe.demo</value>
  41. </constructor-arg>
  42. </bean>
  43.  
  44. <!-- 配置JMS模板(Queue),Spring提供的JMS工具类,它发送、接收消息。 -->
  45. <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
  46. <property name="connectionFactory" ref="connectionFactory" />
  47. <property name="defaultDestination" ref="demoQueueDestination" />
  48. <property name="receiveTimeout" value="10000" />
  49. <!-- true是topic,false是queue,默认是false,此处显示写出false -->
  50. <property name="pubSubDomain" value="false" />
  51. </bean>

  52. </beans>
 

二、代码部分

消息生产者ProducerService.java,代码如下

 
  1. package com.gzframe.demo.activemq.producer;
  2.  
  3. import javax.annotation.Resource;
  4. import javax.jms.Destination;
  5. import javax.jms.JMSException;
  6. import javax.jms.Message;
  7. import javax.jms.Session;
  8.  
  9. import org.springframework.jms.core.JmsTemplate;
  10. import org.springframework.jms.core.MessageCreator;
  11. import org.springframework.stereotype.Service;
  12.  
  13. @Service
  14. public class ProducerService {
  15.  
  16. @Resource(name="jmsTemplate")
  17. private JmsTemplate jmsTemplate;
  18.  
  19. /**
  20. * 向指定队列发送消息
  21. */
  22. public void sendMessage(Destination destination, final String msg) {
  23. System.out.println("向队列" + destination.toString() + "发送了消息------------" + msg);
  24. jmsTemplate.send(destination, new MessageCreator() {
  25. public Message createMessage(Session session) throws JMSException {
  26. return session.createTextMessage(msg);
  27. }
  28. });
  29. }
  30.  
  31. /**
  32. * 向默认队列发送消息
  33. */
  34. public void sendMessage(final String msg) {
  35. String destination = jmsTemplate.getDefaultDestination().toString();
  36. System.out.println("向队列" +destination+ "发送了消息------------" + msg);
  37. jmsTemplate.send(new MessageCreator() {
  38. public Message createMessage(Session session) throws JMSException {
  39. return session.createTextMessage(msg);
  40. }
  41. });
  42.  
  43. }
  44.  
  45. }
 

消费者ConsumerService.java,代码如下

 
  1. package com.gzframe.demo.activemq.consumer;
  2.  
  3. import javax.annotation.Resource;
  4. import javax.jms.Destination;
  5. import javax.jms.JMSException;
  6. import javax.jms.TextMessage;
  7.  
  8. import org.springframework.jms.core.JmsTemplate;
  9. import org.springframework.stereotype.Service;
  10.  
  11. @Service
  12. public class ConsumerService {
  13.  
  14. @Resource(name="jmsTemplate")
  15. private JmsTemplate jmsTemplate;
  16.  
  17. /**
  18. * 接收消息
  19. */
  20. public TextMessage receive(Destination destination) {
  21. TextMessage tm = (TextMessage) jmsTemplate.receive(destination);
  22. try {
  23. System.out.println("从队列" + destination.toString() + "收到了消息:\t"
  24. + tm.getText());
  25. } catch (JMSException e) {
  26. e.printStackTrace();
  27. }
  28.  
  29. return tm;
  30.  
  31. }
  32.  
  33. }
 

三、页面部分

1.首先写一个欢迎页,welcome.jsp如下,

 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Welcome</title>
  8. </head>
  9. <body>
  10. <h1>Welcome!!!</h1>
  11. <h2><a href="producer">去发消息</a></h2>
  12. <h2><a href="receive">从队列中取一个消息</a></h2>
  13. </body>
  14. </html>
 

2.然后是生产者页面jms_producer.jsp,如下

 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>JMS-Producer</title>
  8. </head>
  9. <body>
  10. <h1>JMS-Producer!!!</h1>
  11. <form action="onsend" method="post">
  12.  
  13. MessageText:<textarea name="message">${time }</textarea>
  14.  
  15. <input type="submit" value="提交" />
  16. </form>
  17. <h2><a href="welcome">返回主页</a></h2>
  18. </body>
  19. </html>
 

3.接收者页面queue_receive.jsp,如下

 
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Receive</title>
  8. </head>
  9. <body>
  10. <h1>${textMessage }</h1>
  11. <h2><a href="welcome">返回主页</a></h2>
  12. </body>
  13. </html>
 

四、Controller控制器

1.首先controller到首页welcome页,WelcomeController.java如下:

 
  1. package com.gzframe.demo.mvc.controller;
  2.  
  3. import org.springframework.stereotype.Controller;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.bind.annotation.RequestMethod;
  6. import org.springframework.web.servlet.ModelAndView;
  7.  
  8. @Controller
  9. public class WelcomeController {
  10.  
  11. @RequestMapping(value="/welcome",method=RequestMethod.GET)
  12. public ModelAndView welcome(){
  13. System.out.println("------------welcome");
  14. ModelAndView mv = new ModelAndView();
  15. mv.setViewName("welcome");
  16. return mv;
  17. }
  18.  
  19. }
 

2.然后定义消息生产和消费的控制器,DemoController.java,代码如下

 
  1. package com.gzframe.demo.mvc.controller;
  2.  
  3. import java.io.IOException;
  4. import java.text.SimpleDateFormat;
  5. import java.util.*;
  6.  
  7. import javax.annotation.Resource;
  8. import javax.jms.Destination;
  9. import javax.jms.JMSException;
  10. import javax.jms.TextMessage;
  11. import javax.management.MBeanServerConnection;
  12. import javax.management.remote.JMXConnector;
  13. import javax.management.remote.JMXConnectorFactory;
  14. import javax.management.remote.JMXServiceURL;
  15.  
  16. import org.springframework.stereotype.Controller;
  17. import org.springframework.web.bind.annotation.RequestMapping;
  18. import org.springframework.web.bind.annotation.RequestMethod;
  19. import org.springframework.web.bind.annotation.RequestParam;
  20. import org.springframework.web.servlet.ModelAndView;
  21.  
  22. import com.gzframe.demo.activemq.consumer.ConsumerService;
  23. import com.gzframe.demo.activemq.producer.ProducerService;
  24.  
  25. @Controller
  26. public class DemoController {
  27.  
  28. //队列名gzframe.demo
  29. @Resource(name="demoQueueDestination")
  30. private Destination demoQueueDestination;
  31.  
  32. //队列消息生产者
  33. @Resource(name="producerService")
  34. private ProducerService producer;
  35.  
  36. //队列消息消费者
  37. @Resource(name="consumerService")
  38. private ConsumerService consumer;
  39.  
  40. @RequestMapping(value="/producer",method=RequestMethod.GET)
  41. public ModelAndView producer(){
  42. System.out.println("------------go producer");
  43.  
  44. Date now = new Date();
  45. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  46. String time = dateFormat.format( now );
  47. System.out.println(time);
  48.  
  49. ModelAndView mv = new ModelAndView();
  50. mv.addObject("time", time);
  51. mv.setViewName("jms_producer");
  52. return mv;
  53. }
  54.  
  55. @RequestMapping(value="/onsend",method=RequestMethod.POST)
  56. public ModelAndView producer(@RequestParam("message") String message) {
  57. System.out.println("------------send to jms");
  58. ModelAndView mv = new ModelAndView();
  59. producer.sendMessage(demoQueueDestination, message);
  60. mv.setViewName("welcome");
  61. return mv;
  62. }
  63.  
  64. @RequestMapping(value="/receive",method=RequestMethod.GET)
  65. public ModelAndView queue_receive() throws JMSException {
  66. System.out.println("------------receive message");
  67. ModelAndView mv = new ModelAndView();
  68.  
  69. TextMessage tm = consumer.receive(demoQueueDestination);
  70. mv.addObject("textMessage", tm.getText());
  71.  
  72. mv.setViewName("queue_receive");
  73. return mv;
  74. }
  75.  
  76. /*
  77. * ActiveMQ Manager Test
  78. */
  79. @RequestMapping(value="/jms",method=RequestMethod.GET)
  80. public ModelAndView jmsManager() throws IOException {
  81. System.out.println("------------jms manager");
  82. ModelAndView mv = new ModelAndView();
  83. mv.setViewName("welcome");
  84.  
  85. JMXServiceURL url = new JMXServiceURL("");
  86. JMXConnector connector = JMXConnectorFactory.connect(url);
  87. connector.connect();
  88. MBeanServerConnection connection = connector.getMBeanServerConnection();
  89.  
  90. return mv;
  91. }
  92.  
  93. }
 

五、效果展示

首先访问欢迎页,如下

然后点“去发消息”,进入到如下页面,默认消息框一已经填写了时间,点击提交,会将时间“2015-12-25 11:51:25”提交到qctivemq服务器中,

提交完成后,根据页面代码,会转到欢迎页,在欢迎页中既可以点击“从队列中取一个消息”,效果如下

可以看到,取到的消息即为刚才提交的时间,demo成功!

经过以上操作后的后台输出如下

六、加入监听器

以上例子中,接收消息是靠手动点击接收,下面将配置一个消息监听器“QueueMessageListener.java”,负责自动监听qctiveMQ中的队列消息,

一旦有新消息后,将自动读取消费,妈妈再也不用担心漏掉消息啦!

1.首先写一个监听的类“QueueMessageListener.java”,必须实现“MessageListerner”接口,代码如下

 
  1. package com.gzframe.demo.activemq.listener;
  2.  
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageListener;
  6. import javax.jms.TextMessage;
  7.  
  8. public class QueueMessageListener implements MessageListener {
  9.  
  10. //当收到消息后,自动调用该方法
  11. @Override
  12. public void onMessage(Message message) {
  13.  
  14. TextMessage tm = (TextMessage) message;
  15. try {
  16. System.out.println("QueueMessageListener监听到了文本消息:\t"
  17. + tm.getText());
  18. //do something ...
  19. } catch (JMSException e) {
  20. e.printStackTrace();
  21. }
  22. }
  23.  
  24. }
 

2.写完监听类后,打开activemq.xml配置文件,需要将这个监听配置到文件中,这样,应用加载后,即会加载此监听。
将以下的配置段加入到activemq.xml中

 
  1. <!-- 配置消息队列监听者(Queue) -->
  2. <bean id="queueMessageListener" class="com.gzframe.demo.activemq.listener.QueueMessageListener" />
  3.  
  4. <!-- 显示注入消息监听容器(Queue),配置连接工厂,监听的目标是demoQueueDestination,监听器是上面定义的监听器 -->
  5. <bean id="queueListenerContainer"
  6. class="org.springframework.jms.listener.DefaultMessageListenerContainer">
  7. <property name="connectionFactory" ref="connectionFactory" />
  8. <property name="destination" ref="demoQueueDestination" />
  9. <property name="messageListener" ref="queueMessageListener" />
  10. </bean>
 

3.测试

配置完成后,重新启动服务,去消息发送页提交消息,提交完毕后,监听检测到,将立即消费掉,并在后台打印出来

后台输出如下

spring与actionMQ整合的更多相关文章

  1. 轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)

    轻量级Java EE企业应用实战(第4版):Struts 2+Spring 4+Hibernate整合开发(含CD光盘1张)(国家级奖项获奖作品升级版,四版累计印刷27次发行量超10万册的轻量级Jav ...

  2. Spring Security 3整合CAS 实现SSO

    spring security 3整合cas client用于实现各Application之间的单点登录. 1. 需要准备的jar spring-security-core-3.0.8.RELEASE ...

  3. 1.springMVC+spring+Mybatis的整合思路

    SSM整合的过程:就是把一些东西交给spring管理,也就是添加配置文件的一个过程.那么有哪些东西我们要交给spring管理呢?大概有以下几个: 1.数据源(可配置数据库连接池) 2.SqlSessi ...

  4. Spring+springmvc+Mybatis整合案例 annotation版(myeclipse)详细版

    Spring+springmvc+Mybatis整合案例 Version:annotation版 文档结构图: 从底层开始做起: 01.配置web.xml文件 <?xml version=&qu ...

  5. Spring+springmvc+Mybatis整合案例 xml配置版(myeclipse)详细版

    Spring+springmvc+Mybatis整合案例 Version:xml版(myeclipse) 文档结构图: 从底层开始做起: 01.配置web.xml文件 <?xml version ...

  6. Spring与Mybatis整合的MapperScannerConfigurer处理过程源码分析

    前言 本文将分析mybatis与spring整合的MapperScannerConfigurer的底层原理,之前已经分析过java中实现动态,可以使用jdk自带api和cglib第三方库生成动态代理. ...

  7. Mybatis学习--spring和Mybatis整合

    简介 在前面写测试代码的时候,不管是基于原始dao还是Mapper接口开发都有许多的重复代码,将spring和mybatis整合可以减少这个重复代码,通过spring的模板方法模式,将这些重复的代码进 ...

  8. Spring(八)SSH整合简述

    一.Spring与Struts2的整合 1.1.整合步骤 1.2.配置web.xml 1.3.配置spring配置文件applicationContext.xml 1.4.配置struts配置文件 1 ...

  9. Spring学习6-Spring整合Struts2

    一.Spring为什么要整合Struts2     Struts2与Spring进行整合的根本目的就是要让 Spring为Struts2的Action注入所需的资源对象,它们整合的原理则是只要导入了s ...

随机推荐

  1. Hadoop 三剑客之 —— 分布式计算框架 MapReduce

    一.MapReduce概述 二.MapReduce编程模型简述 三.combiner & partitioner 四.MapReduce词频统计案例         4.1 项目简介      ...

  2. .Net上传文件处理三大范式,及开发注意事项

    最近工作内容涉及到一点前端的内容,把学习到的内容记录下来,在今后的开发过程中,不要犯错.本篇只针对一些刚入职的小白及前端开发人员,大牛请绕道!~ 刚开始我们先不讲上传文件的防范问题,先通过一个例子,让 ...

  3. Fabric1.4源码解析:Peer节点背书提案过程

    以前从来没有写过博客,从这段时间开始才开始写一些自己的博客,之前总觉得写一篇博客要耗费大量的时间,而且写的还是自己已经学会的,觉得没什么必要.但是当开始用博客记录下来的时候,才发现有些学会的地方只是自 ...

  4. Storm 学习之路(六)—— Storm项目三种打包方式对比分析

    一.简介 在将Storm Topology提交到服务器集群运行时,需要先将项目进行打包.本文主要对比分析各种打包方式,并将打包过程中需要注意的事项进行说明.主要打包方式有以下三种: 第一种:不加任何插 ...

  5. JavaScript学习笔记(2)

    常用对象 Boolean Number String Array 数组 Date 日期 Math 数字 RegExp 正则 Global 全局 函数 var m = function(){} 事件 o ...

  6. 【设计模式】行为型02模板方法模式(Template Method Patten)

    五一长假,没有出去,不喜欢嘈杂的人群,玩了会游戏发泄了下憋在心底的戾气,手旁大马克杯里是母亲泡的绿茶.点开自己的播放列表,耳机里传来的是理查德克莱德曼的致爱丽丝.自己是个凡人,卑微渺小的活着.不说废话 ...

  7. Solr配置文件 schema.xml

    1 添加自己的分词器(mmseg4j) 意思是textCommplex 这个类型,用的是 com.chenlb.mmseg4j.solr.MMSegTokenizerFactory 这个分词器,词库是 ...

  8. Java Volatile 关键字详解

    原文链接:https://www.cnblogs.com/zhengbin/p/5654805.html 一.基本概念 先补充一下概念:Java 内存模型中的可见性.原子性和有序性. 可见性: 可见性 ...

  9. select自定义下拉三角符号,css样式小细节

    本来没有写文章的习惯,但是闲下来了,整理资料,发现还挺纠结,对前端来说.所以整理下,希望对看到的人有所帮助,毕竟我不是前端开发. 起因,是前端告诉我select 框的三角箭头不能自定义.但是第二次的时 ...

  10. 大数据 SQL Boy 脱坑指南

    不可否认的是 SQL 是一个伟大的发明,它让增删改查的操作更加地便捷化,而且 SQL 的学习成本相对其他编程语言来说较低,被逼到会写 SQL 的运营和产品我都见过不少... 大数据行业跟 SQL 更是 ...