利用PocketBase加速你的项目进度

在当今快速发展的技术领域,实时数据库已成为构建现代应用程序不可或缺的工具。PocketBase,作为一款开源的实时数据库解决方案,以其类似于Firebase的功能和自托管的能力,为开发者提供了强大的数据管理平台。它不仅提供了实时数据同步和强大的查询功能,还允许用户在自己的服务器上部署和运行数据库,从而确保了数据的安全性和隐私性。

Pocketbase 的应用情景:

  1. 实时应用程序:Pocketbase 适用于需要实时数据同步的应用,如在线聊天、实时通知、多人协作工具等。
  2. 快速原型开发:由于其一体化后端解决方案的特点,Pocketbase 非常适合快速构建和迭代原型。
  3. 小型到中型项目:Pocketbase 适合资源有限的小型到中型项目,可以减少开发和运维的复杂性。
  4. IoT 应用:Pocketbase 可以用于物联网应用,处理实时数据并支持设备间的快速通信。
  5. 移动应用后端:Pocketbase 提供了易于集成的客户端 SDK,非常适合作为移动应用的后端服务。

自带后台管理,以及建表的api

Web API 参考 - API 实时

实时 API 是通过服务器发送的事件 (SSE) 实现的。通常,它由 2 个操作组成:

  1. 建立 SSE 连接
  2. 提交客户端订阅

SDK方法无缝处理所有这些操作:subscribe和``unsubscribe

复制代码
import PocketBase from 'pocketbase';

const pb = new PocketBase('http://127.0.0.1:8090'); 

...

// (Optionally) authenticate
await pb.collection('users').authWithPassword('test@example.com', '1234567890');

// Subscribe to changes in any record in the collection
pb.collection('example').subscribe('*', function (e) {
    console.log(e.action);
    console.log(e.record);
}, { /* other options like expand, custom headers, etc. */ });


// Subscribe to changes only in the specified record
pb.collection('example').subscribe('RECORD_ID', function (e) {
    console.log(e.action);
    console.log(e.record);
}, { /* other options like expand, custom headers, etc. */ });


// Unsubscribe
pb.collection('example').unsubscribe('RECORD_ID'); // remove all 'RECORD_ID' subscriptions
pb.collection('example').unsubscribe('*'); // remove all '*' topic subscriptions
pb.collection('example').unsubscribe(); // remove all subscriptions in the collection

1,导入 PocketBase 库:

复制代码
import PocketBase from 'pocketbase';

这行代码导入了 PocketBase 模块,使得我们可以在代码中使用它提供的功能。

2,创建 PocketBase 实例:

复制代码
const pb = new PocketBase('http://127.0.0.1:8090');

这里创建了一个 PocketBase 的实例,连接到本地的 PocketBase 服务器,地址是 http://127.0.0.1:8090

3,(可选)使用用户名和密码进行身份验证:

复制代码
await pb.collection('users').authWithPassword('test@example.com', '1234567890');

这行代码尝试使用提供的电子邮件和密码对 'users' 集合进行身份验证。authWithPassword 是一个异步函数,需要使用 await 关键字等待其完成。

4,订阅集合中任何记录的变化:

复制代码
pb.collection('example').subscribe('*', function (e) {
    console.log(e.action);
    console.log(e.record);
}, { /* other options like expand, custom headers, etc. */ });

使用 subscribe 方法订阅 'example' 集合中的所有记录。* 表示所有记录,传递给函数的 e 对象包含了事件的 action(比如 'created', 'updated', 'deleted')和改变的 record。

5,仅订阅特定记录的变化:

复制代码
pb.collection('example').subscribe('RECORD_ID', function (e) {
    console.log(e.action);
    console.log(e.record);
}, { /* other options like expand, custom headers, etc. */ });

这行代码订阅 'example' 集合中特定 RECORD_ID 的记录变化。只有当这个特定记录发生变化时,回调函数才会被触发。

6,取消订阅:

复制代码
pb.collection('example').unsubscribe('RECORD_ID'); // 移除特定 'RECORD_ID' 的所有订阅
pb.collection('example').unsubscribe('*'); // 移除所有 '*' 主题的订阅
pb.collection('example').unsubscribe(); // 移除集合中的所有订阅

unsubscribe 方法用来取消订阅。第一个参数是记录 ID 或者 '*' 来指定要取消的订阅类型。如果没有提供参数,则取消集合中所有的订阅。

请注意,上述代码只是一个示例,实际使用时需要根据实际的数据库地址、集合名称和业务逻辑进行相应的调整。

缺点:只能用于Golang和javascript编程环境。

优势:1, 不需要另建websocket。2, 对于表更新能产生回调事件,这是mysql办不到的

请具体查看PocketBase - Open Source backend in 1 file

相关推荐
soda_yo1 小时前
搞不懂作用域链?这篇文章让你一眼秒懂!
javascript·面试
apollo_qwe1 小时前
Set 和 Map常用场景代码片段
javascript
Hilaku1 小时前
我为什么说全栈正在杀死前端?
前端·javascript·后端
资深web全栈开发2 小时前
贪心算法套路解析
算法·贪心算法·golang
程序猿_极客2 小时前
【期末网页设计作业】HTML+CSS+JS 旅行社网站、旅游主题设计与实现(附源码)
javascript·css·html·课程设计·期末网页设计
用户283209679372 小时前
为什么我的页面布局总是乱糟糟?可能是浮动和BFC在作怪!
javascript
枫子有风2 小时前
【go.sixue.work】2.2 面向对象:接口与多态
开发语言·后端·golang·xcode
天然玩家3 小时前
【技术选型】Go后台框架选型
golang·gin·echo·fiber·fasthttp
会篮球的程序猿3 小时前
原生表格文本过长展示问题,参考layui长文本,点击出现文本域
前端·javascript·layui
哆啦A梦15883 小时前
48 我的地址页面布局
javascript·vue.js·node.js