关于为什么创建 R2DBC 的部分答案是需要一个非阻塞应用程序堆栈来处理具有少量线程的并发并使用较少的硬件资源进行扩展。重用标准化的关系数据库访问 API(即 JDBC)无法满足这种需求,因为 JDBC 是一个完全阻塞的 API。尝试使用 a 来补偿阻塞行为
ThreadPool
的用途有限。
答案的另一部分是大多数应用程序使用关系数据库来存储它们的数据。虽然一些 NoSQL 数据库供应商为他们的数据库提供了反应式数据库客户端,但迁移到 NoSQL 并不是大多数项目的选择。这是将新的通用 API 用作任何非阻塞数据库驱动程序的基础的动机。虽然开源生态系统承载着各种非阻塞关系数据库驱动程序实现,但每个客户端都带有特定于供应商的 API,因此在这些库之上的通用层是不可能的。
反应式术语
术语“反应性”是指围绕对变化、可用性和可处理性做出反应而构建的编程模型——网络组件对 I/O 事件做出反应,UI 控制器对鼠标事件做出反应,资源可用等等。从这个意义上说,非阻塞是反应性的,因为我们现在处于对通知作出反应的模式,而不是被阻塞,因为操作完成或数据可用。
反应式API
Reactive Streams 在互操作性方面发挥着重要作用。它对库和基础设施组件很感兴趣,但作为应用程序 API 不太有用,因为它太低级了。应用程序需要一个更高级、更丰富、功能更强大的 API 来组合异步逻辑——类似于 Java 8 Stream API,但不仅限于表。这就是反应式库所扮演的角色。
Project Reactor是 Spring Data R2DBC 的首选反应库。它提供了
Mono
和Flux
API 类型,通过一组与 ReactiveX 运算符词汇表对齐的丰富运算符来处理0..1
(Mono
) 和0..N
(Flux
) 的数据序列。Reactor 是一个 Reactive Streams 库,因此它的所有操作符都支持非阻塞背压。Reactor 非常关注服务器端 Java。它是与 Spring 密切合作开发的。
Spring Data R2DBC 需要 Project Reactor 作为核心依赖项,但它可以通过 Reactive Streams 规范与其他反应式库互操作。作为一般规则,Spring Data R2DBC 存储库接受普通
Publisher
作为输入,在内部将其调整为 Reactor 类型,使用它,并返回 aMono
或 aFlux
作为输出。因此,您可以将任何Publisher
作为输入并在输出上应用操作,但您需要调整输出以与另一个反应库一起使用。只要可行,Spring Data 就会透明地适应 RxJava 或其他反应式库的使用。
个人理解:通过响应式WebFlux 配合 配合反应式数据源,可以通过非阻塞的方式,提升线程的可用性,提升系统的吞吐量,但是响应时长并没多太多的感知。
环境:
jdk: adopt-openjdk-11
maven: 3.8.1
SpringBoot : 2.3.2.RELEASE
Pom文件
org.projectlombok
lombok
org.springframework.boot
spring-boot-starter-data-r2dbc
dev.miku
r2dbc-mysql
0.8.2.RELEASE
org.springframework.boot
spring-boot-starter-data-r2dbc
2.3.0.RELEASE
org.springframework.boot
spring-boot-starter-webflux
application配置文件
r2dbc
spring:
r2dbc:
url: r2dbc:mysql://localhost/r2dbc?useUnicode=true&characterEncoding=UTF-8
username: root
password: root
pool:
enabled: true
max-size: 10
initial-size: 10
validation-query: select 1
表结构
DROP TABLE IF EXISTS user
;
CREATE TABLE user
(
id
int(11) NOT NULL AUTO_INCREMENT,
name
varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
age
int(11) NULL DEFAULT NULL,
email
varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
phone_number
int(11) NULL DEFAULT NULL,
PRIMARY KEY (id
) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 6 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
– Records of user
INSERT INTO user
VALUES (1, ‘admin’, 12, ‘123@163.com’, 145448546);
INSERT INTO user
VALUES (2, ‘tom’, 18, ‘tom@163.com’, 12346789);
INSERT INTO user
VALUES (5, ‘jerry’, 25, ‘jerry@163.com’, 154646126);
SET FOREIGN_KEY_CHECKS = 1;
实体类
/**
-
@author ZhaoJiu
-
@since: 2021/7/22
-
@desc: 用户实体类
*/
@Table(“user”)
@Data
public class User {
@Id
private String id;
private String name;
private Integer age;
private String email;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
最后如何让自己一步步成为技术专家
说句实话,如果一个打工人不想提升自己,那便没有工作的意义,毕竟大家也没有到养老的年龄。
当你的技术在一步步贴近阿里p7水平的时候,毫无疑问你的薪资肯定会涨,同时你能学到更多更深的技术,交结到更厉害的大牛。
推荐一份Java架构之路必备的学习笔记,内容相当全面!!!
成年人的世界没有容易二字,前段时间刷抖音看到一个程序员连着加班两星期到半夜2点的视频。在这个行业若想要拿高薪除了提高硬实力别无他法。
你知道吗?现在有的应届生实习薪资都已经赶超开发5年的程序员了,实习薪资26K,30K,你没有紧迫感吗?做了这么多年还不如一个应届生,真的非常尴尬!
进了这个行业就不要把没时间学习当借口,这个行业就是要不断学习,不然就只能被裁员。所以,抓紧时间投资自己,多学点技术,眼前困难,往后轻松!
【关注】+【转发】+【点赞】支持我!创作不易!
mdGjaYG-1711716000043)]
成年人的世界没有容易二字,前段时间刷抖音看到一个程序员连着加班两星期到半夜2点的视频。在这个行业若想要拿高薪除了提高硬实力别无他法。
你知道吗?现在有的应届生实习薪资都已经赶超开发5年的程序员了,实习薪资26K,30K,你没有紧迫感吗?做了这么多年还不如一个应届生,真的非常尴尬!
进了这个行业就不要把没时间学习当借口,这个行业就是要不断学习,不然就只能被裁员。所以,抓紧时间投资自己,多学点技术,眼前困难,往后轻松!
【关注】+【转发】+【点赞】支持我!创作不易!