0

0

保持用户的同步:与凸的实时协作

聖光之護

聖光之護

发布时间:2025-02-10 08:02:13

|

898人浏览过

|

来源于php中文网

原创

我的创业公司stick,一款实时协作白板应用,灵感源于线下协作的便捷性。stick的开发过程既富有挑战性,也令人兴奋。在完成项目后,我积累了大量经验,涵盖用户同步、高效数据处理以及系统稳定性保障等方面。

保持用户的同步:与凸的实时协作

实时协作的必要性

实时协作对现代工作流程至关重要,无论是头脑风暴、文档编辑还是代码调试,即时反馈都能保持团队活力,实现高效沟通。Google Docs或Figma等应用已成功实现了这一点,而我致力于将这种便捷性引入创意头脑风暴领域。

实时协作的挑战

实时协作的挑战不仅在于数据同步,更在于打造流畅且引人入胜的用户体验。我利用Supabase解决了以下几个关键问题:

数据同步与乐观更新

实时同步数据是协作应用的常见难题。在Stick中,每个用户的更改都需要在所有活跃会话中立即反映。传统方法需要轮询和WebSocket,构建复杂的系统,并涉及大量的自定义逻辑和后端配置。

Supabase的解决方案:Supabase通过其原生实时数据同步机制简化了这一过程。useQuery hook能够轻松获取和同步数据(例如Stick的笔记),配置简便。Supabase处理WebSocket连接的复杂性,确保所有客户端自动保持同步,从而使开发者能够专注于功能开发,而非底层连接管理。

乐观更新:为了提升用户体验,即使在服务器保存后端更改之前,我也立即反映UI变化。

乐观更新的优势:乐观更新解决了网络延迟导致的UI延迟问题。当用户创建新笔记时,即使突变仍在处理中,更改也会立即显示在白板上。如果突变失败,则会回滚更改,确保数据一致性,同时保持流畅的用户体验。

const createNote = useMutation(api.notes.createNote).withOptimisticUpdate(
  (localStore, args) => {
    const existingNotes = localStore.getQuery(api.notes.getNotes, { boardId: actualBoardId }) || [];
    const tempId = `temp_${Date.now()}` as Id;
    const now = Date.now();
    localStore.setQuery(api.notes.getNotes, { boardId: actualBoardId }, [
      ...existingNotes,
      { _id: tempId, _creationTime: now, ...args },
    ]);
  }
);

新注释会立即显示在白板上,用户可以继续协作,无需等待服务器响应。只有当突变结果与预期不符时,UI才会相应更新。

实时在线状态跟踪

实时跟踪用户在线状态和在白板上的位置对实时协作至关重要。在Stick中,我需要显示用户光标位置,指示其他用户在白板上的操作。实时跟踪还能确保团队了解谁在活跃参与。

经验教训:实时跟踪用户光标位置需要频繁更新,如果管理不当,可能会压垮系统。

天天团购系统
天天团购系统

天天团购系统是一套强大的开源团购程序,采用PHP+mysql开发,系统内置支付宝、财付通、GOOGLE地图等接口,支持短信发送团购券和实物团购快递发货等;另外可通过Ucenter模块,与网站已有系统无缝整合,实现用户同步注册、登陆、退出。 天天团购系统是一套创新的开源团购程序,拥有多达10项首创功能,同时支持虚拟和实物团购,内置类似淘宝的快递配送体系,并提供强大的抽奖、邀请返利等营销功能,让您轻松

下载

Supabase的解决方案:我使用了防抖函数来有效管理在线更新频率。此功能通过限制频繁更新来防止数据库被过多的请求淹没。

防抖函数的解释:防抖是一种技术,它只在指定延迟后触发函数,避免冗余或不必要的调用。在本例中,它有助于防止光标的小幅快速移动发送过多的更新。

export function usePresence(boardId: Id, isShared: boolean) {
  // ... (代码与原文相同)
}

通过防抖更新,系统可以有效地跟踪用户活动,而不会压垮后端或导致性能问题。

数据库设计与索引

随着实时数据的增长,高效的数据库设计至关重要。我需要确保随着白板和用户数量的扩展,数据能够快速检索。

Supabase的帮助:Supabase的架构设计允许轻松定义表和索引。例如,在线状态表架构支持基于用户和白板的有效查询,并跟踪每个用户的最后更新时间。

presence: defineTable({
  userId: v.id("users"),
  boardId: v.id("boards"),
  lastUpdated: v.number(),
  cursorPosition: v.object({
    x: v.number(),
    y: v.number(),
  }),
})
  .index("by_board", ["boardId"])
  .index("by_user_and_board", ["userId", "boardId"])
  .index("by_board_and_lastUpdated", ["boardId", "lastUpdated"]);

这些索引确保即使有大量活跃用户或白板,数据检索速度也能保持快速。

端到端类型安全

Supabase与TypeScript的无缝集成是其主要优势之一。TypeScript提供的类型安全在构建实时系统时非常重要。通过类型安全的查询、突变和模式定义,我能够在开发过程中捕获潜在错误,使整个过程更流畅、更可预测。

经验与总结

我了解到高效的状态管理至关重要。实时系统固然复杂,但使用合适的工具可以显著简化开发。Supabase让我能够专注于打造出色的用户体验,而无需过多关注底层技术细节。

Stick的开发是一次有意义的经历,让我学习了大量关于实时系统的知识,以及如何使用工具简化复杂任务。对于希望实现类似功能的开发者,我的建议是从小型项目开始,充分利用现有工具,并在学习过程中迭代改进。

访问Stick项目体验这些功能,或查看源代码了解更多实现细节。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

352

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2075

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

410

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

404

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

221

2023.10.19

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
TypeScript 教程
TypeScript 教程

共19课时 | 2.3万人学习

TypeScript——十天技能课堂
TypeScript——十天技能课堂

共21课时 | 1.1万人学习

TypeScript-45分钟入门
TypeScript-45分钟入门

共6课时 | 0.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号