当前位置: 首页 > news >正文

大连中小网站建设公司郑州网站建设推广

大连中小网站建设公司,郑州网站建设推广,工作日巴士驾驶2,网络的基本概念上篇讲述高并发情况下的数据库处理方式:分布式事务管理机制。即使我们做到这一步并发情况只能稍微得到缓解,当然千万级别的问题不大,但在面对双十一淘宝这类的达上亿的并发的时候仅仅靠分布式事务管理还是远远不够,即使数据库可以…

        上篇讲述高并发情况下的数据库处理方式:分布式事务管理机制。即使我们做到这一步并发情况只能稍微得到缓解,当然千万级别的问题不大,但在面对双十一淘宝这类的达上亿的并发的时候仅仅靠分布式事务管理还是远远不够,即使数据库可以抗住压力,但从前端访问上并不能根本解决数据库可重复读的问题。

        解决并发问题的方式很多单都无法彻底解决并发问题,因为并发问题以现有的技术无法解决,但我们可以尽可能的使系统无线扩大并发量以达到完全处理并发的效果,限流、熔断都是不错的选择,但会出现系统无法访问的情况,当并发进入到系统的时候直接处理业务功能显然不合适,如果把并发进行队列化操作显然更加合适公平。举个栗子,做核酸检测的医护人员就几个而做核酸检测的人却多的数不过来,如果这些人一块围着谁也做不了核酸,此时排队等待是最适合的先到先排先做。MQ就是维持秩序的管理员,将并发进行排队。

1、MQ介绍

        当今市面上有很多主流的消息中间件,如老牌的ActiveMQ、RabbitMQ,炙手可热的Kafka,阿里巴巴自主开发的Notify、MetaQ、RocketMQ等。

        本文使用ActiveMQ,无论哪种MQ技术都会涉及到消息的存储性、可靠性、传递性等,基本属性都会包含消息生产者、消费者两部分,推送方式一般为订阅广播、点对点的方式。字面意思广播就是通过网络广播发送消息,MQ不关注接收方是否在线,点对点是A端到B端双方进行握手通信后再传输数据。两者比较广播效率更高,但数据丢失率也高,数据安全性低,点对点传输效率相对广播低、数据丢失率低、如果B端掉线消息可以做持久化存储,等待B端上线握手后再次发送。

2、windows系统MQ服务部署

        官网:https://activemq.apache.org/

        官网提供两个版本的MQ供下载,Classic版本为当前稳定版本,Artemis版本为下代版本本文使用Classic版本。下载windows版本的压缩包ActiveMQ 5.16.5.zip。各版本的MQ对应Java JDK版本要看清楚。

        下载完成后解压zip,进入到MQ文件夹下如下:

         进入bin目录下,根据系统选择32位或者64位进入文件夹,运行activemq.bat脚本。

        本地访问http://localhost:8161账号/密码为admin

        点击进入管理界面,至此MQ服务启动成功。消息管理中心有Queues,Topics,Subscribers等我们可以查看队列、订阅等信息。

        Topics:是基于“订阅-发布”模式,当操作者发布一条消息后,所有对这条消息感兴趣的订阅者都可以收到它——也就是说这条消息会被拷贝成多份,进行分发。只有当前“活动的”订阅者能够收到消息。

        Queues:是一种“负载均衡模式”的实现。一个消息能且只能被一个消费者接受。如果当前JMS-Queue中没有任何的消费者,那么这条消息将会被Queue存储起来(实际应用中可以存储在磁盘上,也可以存储在数据库中,看软件的配置),直到有一个消费者连接上。另外,如果消费者在接受到消息后,在他断开与JMS-Queue连接之前,没有发送ack信息(可以是客户端手动发送,也可以是自动发送),那么这条消息将被发送给其他消费者。

比较项目Topic 模式队列Queue 模式队列
工作模式“订阅-发布”模式,如果当前没有订阅者,消息将会被丢弃。如果有多个订阅者,那么这些订阅者都会收到消息“负载均衡”模式,如果当前没有消费者,消息也不会丢弃;如果有多个消费者,那么一条消息也只会发送给其中一个消费者,并且要求消费者ack信息。
有无状态无状态Queue数据默认会在mq服务器上以文件形式保存,比如Active MQ一般保存在$AMQ_HOME\data\kr-store\data下面。也可以配置成DB存储。
传递完整性如果没有订阅者,消息会被丢弃消息不会丢弃
处理效率由于消息要按照订阅者的数量进行复制,所以处理性能会随着订阅者的增加而明显降低,并且还要结合不同消息协议自身的性能差异由于一条消息只发送给一个消费者,所以就算消费者再多,性能也不会有明显降低。当然不同消息协议的具体性能也是有差异的

3、系统集成

        服务启动后我们需要在系统中集成MQ并进行收发消息测试,在父工程下创建MQ子工程。在子工程pom中添加MQ依赖。

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-activemq</artifactId>
</dependency>
<dependency><groupId>org.apache.activemq</groupId><artifactId>activemq-pool</artifactId>
</dependency>

        在启动类上添加注解@EnableJms。

在需要使用MQ进行业务处理的服务中依赖MQ服务,并添加MQ配置信息:

server:port: 8081
spring:activemq:broker-url: tcp://127.0.0.1:61616user: adminpassword: adminjms:pub-sub-domain: true # 默认为false,点对点模式queue  true订阅模式topicpool:enabled: false # 是否创建 JmsPoolConnectionFactory 连接池idle-timeout: 30s # 空闲连接超时时间max-connections: 50 # 连接池中最大连接数max-sessions-per-connection: 100 # 每个连接最大会话

        编写MQ配置类:

@Configuration
public class BeanConfig {@Value("${spring.activemq.broker-url}")private String brokerUrl;@Value("${spring.activemq.user}")private String userName;@Value("${spring.activemq.password}")private String password;//定义存放消息的队列@Beanpublic ActiveMQQueue queue() {return new ActiveMQQueue("MyQueue");}@Beanpublic ActiveMQTopic topic() {return new ActiveMQTopic("MyTopic");}@Beanpublic ConnectionFactory connectionFactory() {return new ActiveMQConnectionFactory(userName, password, brokerUrl);}/*** 在 Queue 模式中,对消息的监听需要对containerFactory进行配置*/@Bean("queueListener")public JmsListenerContainerFactory<?> queueJmsListenerContainerFactory(ConnectionFactory connectionFactory) {SimpleJmsListenerContainerFactory factory = new SimpleJmsListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setPubSubDomain(false);return factory;}/*** 在 topic 模式中,对消息的监听需要对containerFactory进行配置*/@Bean("topicListener")public JmsListenerContainerFactory<?> topicJmsListenerContainerFactory(ConnectionFactory connectionFactory) {SimpleJmsListenerContainerFactory factory = new SimpleJmsListenerContainerFactory();factory.setConnectionFactory(connectionFactory);factory.setPubSubDomain(true);return factory;}
}

        编写Queue监听类和Topic监听类:

@Component
public class MyQueueListener {@JmsListener(destination = "MyQueue", containerFactory="queueListener")public void handleMessage(String name) {System.err.println(name);}}

 

@Component
public class MyTopicListener {@JmsListener(destination = "MyTopic", containerFactory="topicListener")public String handleMessage1(String name) {System.out.println("topic 成功接受Name" + name);}
}

        编写消息发送接口 :


@Controller
@RestController("/demo")
public class Demo {@Autowiredprivate Queue queue;@Autowiredprivate JmsMessagingTemplate jmsMessagingTemplate;/*** 发送消息接口* @param msg*/@GetMapping("/{msg}")void demo(@PathVariable String msg) {// 消息入队列jmsMessagingTemplate.convertAndSend(queue, msg);}}

         访问接口传入消息参数:

         

        可以看到控制台打印输出消息内容。至此系统集成MQ完成。

 

http://www.zhongyajixie.com/news/27393.html

相关文章:

  • 教育网站建设 飞沐西地那非片吃了能延时多久
  • 狗和人做网站seo关键词挖掘工具
  • 网站做付费推广都需要问什么拉新推广一手接单平台
  • 中国建设银行网站医保教育培训网站大全
  • 天津快速排名深圳关键词优化软件
  • 应价交易系统网站开发慧聪网
  • 网站做优化有什么用吗百度关键词刷排名软件
  • 北京好的网站开发360收录批量查询
  • 北京市网站设计-推广公司江苏做网站的公司有哪些
  • 兼职做效果图的网站有哪些网站运营主要做什么
  • 个人网站花多少钱百度关键词优化大
  • 收藏网站怎么做不受国内限制的浏览器
  • 用dw制作网站模板下载seo在线论坛
  • 阿里云服务器做盗版视频网站网络营销的概念和特点
  • 如何做指数交易网站怎样在百度上建立网站
  • 如何看网站有没有备案广告代运营
  • 公司网站手机版惠州seo外包平台
  • 网站版权信息模板深圳百度推广属于哪家公司
  • 在线网站建设价格多少站长之家查询的网址
  • 个人网站备案做论坛东莞网站建设方案外包
  • 发烧病例单子图片在线制作荥阳seo推广
  • 国外网站建设软件东莞关键词排名seo
  • 罗湖网站建设58网络推广渠道公司
  • 任县网站建设设计在线看网址不收费不登录
  • 东营最新新闻重庆seo整站优化方案范文
  • 深圳短视频推广收费百度网站优化工具
  • 宝安网站制作哪家强企业培训课程设计
  • 微信小程序怎么做网站链接百度长尾关键词挖掘工具
  • 做网站的好公司有哪些东莞搜索引擎推广
  • 宜昌网站建设厂家百度推广电话