Project Icon

pocketbase

轻量级开源后端框架 单文件实现多功能

PocketBase是一款开源Go后端框架,整合嵌入式SQLite数据库、实时订阅、文件及用户管理、管理面板UI和REST API。可独立运行或作为Go开发工具使用,便于构建定制化业务逻辑。提供JavaScript和Dart SDK,适用于多平台开发。

PocketBase - 单文件开源后端

构建 最新版本 Go包文档

PocketBase是一个开源的Go后端,包含以下特性:

  • 嵌入式数据库(SQLite)支持实时订阅
  • 内置文件和用户管理
  • 便捷的管理仪表板界面
  • 简单的REST风格API

有关文档和示例,请访问https://pocketbase.io/docs。

[!警告] 请注意,PocketBase仍在积极开发中, 因此在达到v1.0.0版本之前不能保证完全向后兼容。

API SDK客户端

与API交互最简单的方式是使用官方SDK客户端之一:

概述

作为独立应用使用

您可以从发布页面下载适用于您平台的预构建可执行文件。 下载后,解压缩文件并在解压目录中运行./pocketbase serve

预构建的可执行文件基于examples/base/main.go文件,默认启用了JS VM插件,允许使用JavaScript扩展PocketBase(有关详细信息,请参阅使用JavaScript扩展)。

作为Go框架/工具包使用

PocketBase作为常规Go库包分发,允许您构建自己的自定义应用程序特定业务逻辑,同时最终得到一个可移植的单一可执行文件。

以下是一个最小示例:

  1. 安装Go 1.21+如果尚未安装

  2. 创建一个新的项目目录,并在其中创建以下main.go文件:

    package main
    
    import (
        "log"
        "net/http"
    
        "github.com/labstack/echo/v5"
        "github.com/pocketbase/pocketbase"
        "github.com/pocketbase/pocketbase/apis"
        "github.com/pocketbase/pocketbase/core"
    )
    
    func main() {
        app := pocketbase.New()
    
        app.OnBeforeServe().Add(func(e *core.ServeEvent) error {
            // 在应用路由器(echo)中添加新的"GET /hello"路由
            e.Router.AddRoute(echo.Route{
                Method: http.MethodGet,
                Path:   "/hello",
                Handler: func(c echo.Context) error {
                    return c.String(200, "Hello world!")
                },
                Middlewares: []echo.MiddlewareFunc{
                    apis.ActivityLogger(app),
                },
            })
    
            return nil
        })
    
        if err := app.Start(); err != nil {
            log.Fatal(err)
        }
    }
    
  3. 要初始化依赖项,运行go mod init myapp && go mod tidy

  4. 要启动应用程序,运行go run main.go serve

  5. 要构建静态链接的可执行文件,可以运行CGO_ENABLED=0 go build,然后使用./myapp serve启动创建的可执行文件。

[!注意] PocketBase嵌入了SQLite,但不需要CGO。

如果启用CGO(即CGO_ENABLED=1),它将使用mattn/go-sqlite3驱动程序,否则使用modernc.org/sqlite。 只有在真正需要以牺牲交叉编译复杂性为代价来提高读/写查询性能时才启用CGO。

有关更多详细信息,请参阅使用Go扩展

构建和运行仓库main.go示例

要构建最小的独立可执行文件(类似于发布页面中的预构建文件),您可以在examples/base目录中简单地运行go build

  1. 安装Go 1.21+如果尚未安装
  2. 克隆/下载仓库
  3. 导航到examples/base
  4. 运行GOOS=linux GOARCH=amd64 CGO_ENABLED=0 go build (_https://go.dev/doc/install/source#environment_)
  5. 通过运行./base serve启动创建的可执行文件。

请注意,纯Go SQLite驱动程序目前支持的构建目标是:

darwin  amd64
darwin  arm64
freebsd amd64
freebsd arm64
linux   386
linux   amd64
linux   arm
linux   arm64
linux   ppc64le
linux   riscv64
linux   s390x
windows amd64
windows arm64

测试

PocketBase包含单元测试和集成测试的混合。 要运行它们,使用标准的go test命令:

go test ./...

另请查看测试指南,了解如何编写自己的自定义应用程序测试。

安全

如果您在PocketBase中发现安全漏洞,请发送电子邮件至support at pocketbase.io

所有报告都将得到及时处理,您将得到相应的认可。

贡献

PocketBase是根据MIT许可证授权的免费开源项目。 您可以自由地使用它,甚至可以将其作为付费服务提供。

您可以通过以下方式帮助继续其开发:

欢迎提交新的OAuth2提供商、错误修复、代码优化和文档改进的PR。

但请避免在没有事先讨论实现细节的情况下为_新功能_创建PR。 PocketBase有一个路线图,我尝试按特定顺序处理问题,这样的PR往往会突然出现,扰乱了最初的规划,导致繁琐的来回沟通。

如果我关闭了您的PR,即使它执行良好且经过测试,也不要沮丧。这并不意味着它永远不会被合并。 当时机成熟时,我们可以随时参考它并/或在处理该问题时采用您实现的部分内容(不用担心,您会在发布说明中得到认可)。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号