news 2026/5/1 9:10:00

VonaJS提供的读写分离,直观,优雅[特殊字符]

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
VonaJS提供的读写分离,直观,优雅[特殊字符]

在VonaJS中实现读写分离,只需提供一组写数据源和一组读数据源。当用户访问后端 API 时,系统会按照规则自动选择写数据源或读数据源,访问相应的数据库,从而分摊压力,提升系统性能

安装模块

读写分离作为独立的模块提供,因此需要在VonaJS项目中安装此模块:

$ pnpm add vona-module-a-datasharding -w

添加数据源

首先,需要添加一组数据源

1. 添加类型定义

为新数据源添加类型定义

src/backend/config/config/config.ts

declare module 'vona-module-a-orm' {

export interface IDatabaseClientRecord {

read1: never;

read2: never;

write1: never;

write2: never;

}

}

2. 增加数据源配置

src/backend/config/config/config.ts

// database

config.database = {

clients: {

read1: {

client: 'pg',

connection: {

host: '127.0.0.1',

port: 5432,

user: 'postgres',

password: '',

database: 'xxxx-read1',

},

},

read2: {...},

write1: {...},

write2: {...},

},

};

配置读写数据源

然后配置模块的读写数据源

src/backend/config/config/config.ts

// modules

config.modules = {

'a-datasharding': {

client: {

reads: ['read1', 'read2'],

writes: ['write1', 'write2'],

randomRead: undefined,

randomWrite: undefined,

},

},

};

名称 说明

reads 指定一组读数据源

writes 指定一组写数据源

randomRead 可指定自定义函数,从reads中提取一个读数据源。默认为undefined,由系统随机提取

randomWrite 可指定自定义函数,从writes中提取一个写数据源。默认为undefined,由系统随机提取

读写分离的运行机制

当配置好读写数据源之后,读写分离机制就自动生效了

现在,解释一下读写分离的运行机制:

模块提供了一个全局拦截器a-datasharding:datasharding。该拦截器判断当前 API Method,如果是POST/PATCH/DELETE/PUT,那么就使用写数据源,否则使用读数据源

数据一致性: 缓存写数据源

场景分析:同一个用户

由于数据库同步有延时,会出现数据不一致性的情况。比如,用户访问Write-API,将数据写入写数据库。接下来,用户访问Read-API,此时读数据库还没有同步,那么就会读到旧数据

为了解决以上问题,模块自动提供了一个机制:当用户访问Write-API时,会自动将写数据源存入二级缓存,并设置过期时间。在这个时间之内,用户访问Read-API时,也会继续使用同一个写数据源,从而确保在写入数据后总是可以读取到最新的数据

修改过期时间

二级缓存的名称是a-datasharding:datasourceWrite,可以在 App config 中修改过期时间:

src/backend/config/config/config.ts

// onions

config.onions = {

summerCache: {

'a-datasharding:datasourceWrite': {

mem: {

ttl: 5 * 1000, // 5s

},

redis: {

ttl: 5 * 1000, // 5s

},

},

},

};

名称 说明

mem.ttl Mem缓存的过期时间,默认为3秒

redis.ttl Redis缓存的过期时间,默认为3秒

数据一致性: 缓存双删

场景分析:不同用户

Vona ORM 提供了开箱即用的缓存机制,参见:缓存

由于数据库同步有延时,会出现缓存不一致性的情况。比如,用户 A 访问Write-API,将数据写入写数据库,并自动删除缓存。接下来,用户 B 访问Read-API,此时读数据库还没有同步,那么就会读到旧数据,并存入缓存

为了解决以上问题,模块a-orm提供了缓存双删机制:当用户 A 访问Write-API时,将数据写入写数据库,并自动删除缓存。然后在指定时间之后再次删除缓存,从而确保缓存总是最新数据

启用缓存双删

src/backend/config/config/config.ts

// modules

config.modules = {

'a-orm': {

sharding: {

cache: {

doubleDelete: true,

},

},

},

};

修改缓存双删延迟时间

系统采用队列任务执行缓存双删,队列名称是a-orm:doubleDelete,可以在 App config 中修改缓存双删延迟时间:

src/backend/config/config/config.ts

// onions

config.onions = {

queue: {

'a-orm:doubleDelete': {

options: {

job: {

delay: 5 * 1000, // 5s

},

},

},

},

};

名称 说明

job.delay 指定延迟多长时间执行缓存双删任务,默认为3秒

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 9:08:02

鸿蒙6.0:AI与智能体框架(HMAF),重塑操作系统未来的核心密码

当用户说出“帮我规划带老人孩子的周末短途游”,系统便能自动整合行程、餐饮、景点资源生成完整方案;当驾车抵达加油站,车载系统自动识别油枪并完成人脸支付;当需要分析Excel数据,仅凭自然语言就能完成复杂报表生成——…

作者头像 李华
网站建设 2026/4/27 17:55:56

【往届均已成功见刊检索、早鸟优惠】第六届计算机网络安全与软件工程国际学术会议(CNSSE 2026)

第六届计算机网络安全与软件工程国际学术会议(CNSSE 2026)将于2026年2月6-8日在中国-青岛举行。CNSSE 2026专注于计算机网络安全、软件工程、信号处理、程序分析等领域,致力于搭建计算机领域学术资源共享平台,扩大国际科研学术合作…

作者头像 李华
网站建设 2026/4/23 20:59:22

你必须知道的TCP和UDP核心区别,快速搞懂这两大协议!

1. TCP (Transmission Control Protocol)概念TCP(传输控制协议)是一种面向连接的、可靠的传输协议。它负责将数据从源主机传输到目标主机,并确保数据的完整性、顺序和正确性。原理三次握手:在数据传输之前,TCP协议通过…

作者头像 李华
网站建设 2026/4/29 21:49:00

什么是智能体工程Agent Engineering?

文章介绍了智能体工程这一新兴领域,它是将不可靠的大模型系统转化为生产环境稳定应用的方法论。强调构建、测试、上线、观察、优化的循环过程,需要产品思维、工程能力和数据科学的配合。与传统开发不同,智能体工程将生产环境视为最佳学习场所…

作者头像 李华
网站建设 2026/4/26 19:01:52

基于大数据的热点话题分析系统的设计与实开题报告 (1)

毕业论文(设计)开题报告题 目基于大数据的热点话题分析系统的设计与实现学 院专 业年 级开题日期学 号姓 名指导教师选题的目的、意义、研究现状,本选题研究的基本内容、拟解决的主要问题:1、选题的目的和意义基于大数据的热…

作者头像 李华
网站建设 2026/4/26 9:43:21

GPT 技术原理详解 - 从“顺口溜”到智能对话

引言 2022 年 11 月,ChatGPT 横空出世,瞬间引爆了全球对 AI 的关注。很多人第一次发现,原来 AI 可以写诗、写代码、写论文,甚至可以陪你聊天解闷。 但当你问"ChatGPT 是怎么工作的",得到的回答往往是一堆让…

作者头像 李华