1.生产者消费者模式 不属于23种设计模式,23种设计模式解决类于类之间的关系。该模式处理并发线程通信,线程协作。 应用场景:生产者和消费者的问题 假设:仓库中只能存放一件产品,生产者将生产出来的产品放入仓库,消费者将仓库中产品取走消费 如果仓库中没有产品,则生产者将产品放入仓库,否则停止生产并等待 ...
分类:
编程语言 时间:
2020-07-27 13:43:48
阅读次数:
68
值得思考的问题: 多个线程除了在时序上可能产生相互依赖,在其他方面是否也可能产生相互依赖呢? 生产消费者问题:-有n个生产者同时制造产品,并把产品存入仓库中 -有m个消费者同时需要从仓库中取出产品 -规则: 当仓库未满,任意生产者可以存入产品 当仓库未空,任意消费者可以取出产品 编程实验:生产消费者 ...
分类:
编程语言 时间:
2020-07-26 22:50:37
阅读次数:
60
概述 数据同步场景类型: 主数据库与备份数据库之间的数据备份; 主系统与子系统间的数据更新; 属于同类型不同集群数据库间的数据同步; 不同区域、不同数据库类型间的数据传输交换; 大数据系统:数据从业务系统同步进入数据仓库、数据从数据仓库同步进入数据服务或者数据应用。(本篇主讲数据从业务系统同步进入数 ...
分类:
其他好文 时间:
2020-07-26 19:27:15
阅读次数:
68
线程阀:一种线程与线程之间相互制约和交互的机制。 Queue(队列):用于保存一组元素,存取时,遵循先进先出原则。 队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。 进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为 ...
分类:
编程语言 时间:
2020-07-26 19:12:55
阅读次数:
61
RabbitMq高级特性之死信队列 又称 死信交换机 DLX 当消息成为 Dead message 后,会重新发送到另一个交换机,这个交换机就是 DLX 消息成为死信的情况公有三种: 队列消息长度达到限制 消费者拒接消费消息 basicNack/basicReject,并且不把消息重新放回原目标队列 ...
分类:
其他好文 时间:
2020-07-26 01:01:14
阅读次数:
126
RabbitMq高级特性之延迟队列 消息进入队列后不能立即被消费,到达指定时间后才可被消费 实现 结合以下两种即可达到延迟队列 RabbitMq高级特性之TTL过期时间 RabbitMq高级特性之DLX死信队列 延迟队列小结 延迟队列 指消息进入队列后,经过一定时间后,才能被消费者消费 Rabbit ...
分类:
其他好文 时间:
2020-07-26 01:00:32
阅读次数:
87
4.3.2 等待/通知机制 一个线程修改了一个对象的值,而另一个线程感知到了变化,然后进行相应的操作,整个过程开始于一个线程,而最终执行又是另一个线程。前者是生产者,后者就是消费者,这种模式隔离了“做什么”(what)和“怎么做”(How),在功能层面上实现了解耦,体系结构上具备了良好的伸缩性,但是 ...
分类:
编程语言 时间:
2020-07-25 23:37:56
阅读次数:
68
一、总体介绍 使用一个 Dept 部门模块做一个微服务通用案例 Consumer消费者(Client)通过 REST 调用 Provider 提供者(Server)提供的服务。 一个父工程中创建多个 Module 子模块:MicroServiceCloud父工程(Project)下初次带着三个子模块 ...
分类:
编程语言 时间:
2020-07-24 21:11:42
阅读次数:
72
入门级demo,并没有数据库之类的! 1、项目结构 一个empty project下有两个module: boot-user-service-provider(服务提供者) 和 boot-order-service-consumer(服务消费者) 至于怎么在一个空项目下创建多个module自己去百度 ...
分类:
编程语言 时间:
2020-07-24 16:39:04
阅读次数:
76
==背景== 物联网场景,在设备端写了一个小的API服务程序,这个程序包括: 1、向平台上报设备数据 2、创建消费者客户端,用来监听平台的下行命令 ==问题== 平台层需要知道设备的状态:在线 or 离线。我能想到的解决办法 1、设备上报心跳数据,平台通过心跳来判断设备是否在线。 2、rocketm ...
分类:
其他好文 时间:
2020-07-24 15:29:50
阅读次数:
91