接口数据推拉的东东20190424

2023-11-01 15:10

本文主要是介绍接口数据推拉的东东20190424,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接口数据推拉的东东

1,什么是接口推送/拉取数据

2,如何选择推送/拉取数据

3,推送/拉取数据优缺点

4,总结

 

1,什么是接口推送/拉取数据

推送VS拉取

推送与拉取是两种不同系统间的通信,这两种方式解释了数据生产者数据消费者是如何进行数据交互的.

推送

推送是数据生产者把生产的存储的数据传输到数据消费者里(消费者提供接收的接口),数据消费者是不知何时能接收到何时的数据,消费者接收到数据的时点是由数据生产者决定的.(业务时点可触发,可定时)

拉取

拉取是数据消费者从数据生产者get数据源,数据生产者只需要提供数据源(提供数据源的接口),不用关心,也不知道数据消费者何时获取该数据.数据消费者决定获取数据的时点(定时)

接口类型

数据生产者

数据消费者

拉取

被动的:当被请求时提供数据源。

主动的:决定何时请求去获取数据。

推送

主动的:按自己的时点(业务时点/定时时点)传输数据。

被动的:对收到的数据做出反应。

 

2,如何选择推送/拉取数据

推送

若果数据实时性要求比较强,可采用数据生产端推送.

推送案例

订单系统的订单数据出库后实时转到售后系统生成派工单,工程师派工处理等.(由订单系统推送到售后系统)

推送案例分析

一些企业对派工效率要求比较,提高服务效率,提升品牌的服务口碑.若果让售后系统定时主动获取订单系统出库未派工数据,难以保证出库数据的实时性准确性,不停轮询抓取数据,也会导致系统有不必要的系统性能消耗.

拉取

若果数据实时性不强,宜采用数据消费端拉取数据.

拉取案例

订单系统的发票数据开票回写实时性要求不强,只需要开票中的发票数据定时取对应的数据进行开票状态更新等相关操作.

拉取案例分析

不知道怎么分析了.............

知道的帮忙补充下,谢谢!

 

3,推送/拉取数据优缺点

接口类型

优点

缺点

拉取

1,减轻数据生产者端的系统压力

1,容易发生漏拉取的数据,还难以发现具体明细数据

2,增加空轮询,增加额外性能开销

推送

1,实时性高,数据消费者端能第一时间接收到最新数据

1,不能确保每次推送都成功被接收,需有未确认成功重推机制(数据生产者端复杂化)

2,数据消费者端每次被动接收非空数据,避免空轮询的额外开销,减少服务压力

2,缺乏数据的多样性,可能有比较大的数据冗余存在.(数据消费者端无法根据自身需要固定要自身业务相关的数据字段)

3,数据消费者端接口简单化

 

 

4,总结

个人观点

个人认为在实际工作中,同一个接口应采用混合方式.混合式是同一接口指既有推送也有拉取!以推送为,以拉取为!拉取数据为辅是指手动触发拉取数据!

为什么个人观点采用混合呢

当开发时间充足,采取推送为主,达到数据时效性高,系统性能额外开销减少!当系统推送部分数据异常导致局部推送漏或者,接收数据方异常多次没成功接收数据,需要人为触发拉取数据以解决该异常问题!

客观观点

考虑到开发周期问题,根据业务需求,系统架构等方面考虑,主要按照时间,效率,工作量,是否需求数据实时性特别高等再选择接口采取哪种方式!不管是选用哪种形式,都要根据业务的特性来设计,合理地利用接口来实现业务,必要时选用管道、队列、视图、异步、消息队列等方法。

 

 

感谢大家观看!

如有错误请指出互相交流,让小弟也学习学习,谢谢!

 

 

 

 

这篇关于接口数据推拉的东东20190424的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323877

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

更改docker默认数据目录的方法步骤

《更改docker默认数据目录的方法步骤》本文主要介绍了更改docker默认数据目录的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1.查看docker是否存在并停止该服务2.挂载镜像并安装rsync便于备份3.取消挂载备份和迁

不删数据还能合并磁盘? 让电脑C盘D盘合并并保留数据的技巧

《不删数据还能合并磁盘?让电脑C盘D盘合并并保留数据的技巧》在Windows操作系统中,合并C盘和D盘是一个相对复杂的任务,尤其是当你不希望删除其中的数据时,幸运的是,有几种方法可以实现这一目标且在... 在电脑生产时,制造商常为C盘分配较小的磁盘空间,以确保软件在运行过程中不会出现磁盘空间不足的问题。但在

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

Mybatis拦截器如何实现数据权限过滤

《Mybatis拦截器如何实现数据权限过滤》本文介绍了MyBatis拦截器的使用,通过实现Interceptor接口对SQL进行处理,实现数据权限过滤功能,通过在本地线程变量中存储数据权限相关信息,并... 目录背景基础知识MyBATis 拦截器介绍代码实战总结背景现在的项目负责人去年年底离职,导致前期规