聊聊嵌入式数据库

AI摘要
ZibllAI

本文介绍嵌入式数据库的概念与特点,它直接集成到应用程序内部,无需独立服务器进程,数据以本地文件存储,部署简单。SQLite、BoltDB、BadgerDB 等被广泛用于桌面应用、浏览器扩展、IoT 设备和 Go 项目。它在单机服务、本地缓存和配置存储等场景表现优异,但不适用于高并发写入和多服务器共享。

嵌入式数据库是直接集成到应用程序内部的数据库,无需独立的服务器进程或端口监听,部署简单,数据以本地文件形式存储。常见的有 SQLite、BoltDB、BadgerDB、Pebble、LevelDB、RocksDB、LMDB 等,广泛用于桌面应用、浏览器扩展、IoT 设备和 Go 项目。

嵌入式数据库具有部署简单、性能良好、便于发布和数据本地化等优势,但不适合高并发写入和多服务器共享场景。在单机服务、本地缓存、配置存储和日志系统中表现突出,SQLite 已被微信、Chrome、Firefox、VS Code、Android 和 iOS 等广泛采用。

> 提到数据库,大多数人首先想到的都是 MySQL、PostgreSQL 或 Redis。但近年来,越来越多的桌面应用、浏览器扩展、边缘计算、IoT 设备,甚至一些后端服务,也开始选择使用嵌入式数据库。那么,什么是嵌入式数据库?它又有哪些优势?

什么是嵌入式数据库?

嵌入式数据库(Embedded Database)是一种直接集成到应用程序内部的数据库。

它不像 MySQL 或 PostgreSQL 那样需要单独安装数据库服务,而是作为一个库文件随程序一起运行。

也就是说:

  • 没有数据库服务器
  • 没有独立进程
  • 不需要监听端口
  • 不需要额外部署

应用程序可以直接读写数据库文件。

整个架构更加轻量。

与传统数据库有什么区别?

传统数据库通常采用客户端 / 服务端架构。

应用程序
    │
    ▼
MySQL Server
    │
    ▼
数据库文件

而嵌入式数据库则更加简单。

应用程序
    │
    ▼
嵌入式数据库
    │
    ▼
数据库文件

整个过程不需要网络通信,也没有额外的数据库服务。

常见的嵌入式数据库

目前比较流行的嵌入式数据库主要有下面几种。

| 数据库 | 特点 | 适用场景 | | ——– | ————– | ———– | | SQLite | 最经典、最成熟 | 手机 App、桌面软件 | | BoltDB | Go 原生 KV 数据库 | Go 项目、本地配置 | | bbolt | BoltDB 的维护版本 | Go 服务 | | BadgerDB | 高性能 LSM 数据库 | 缓存、本地索引 | | Pebble | CockroachDB 使用 | 高性能 KV | | LevelDB | Google 开源 | 浏览器、缓存 | | RocksDB | Facebook 开源 | 大数据存储 | | LMDB | 内存映射数据库 | 高性能读取 |

不同数据库各有特点。

例如 SQLite 更偏向关系型数据库。

而 BoltDB、BadgerDB 更适合作为 Key-Value 存储。

为什么越来越受欢迎?

1. 部署简单

这是最大的优势。

很多 Go 项目最终只需要一个可执行文件。

如果数据库也是嵌入式的,那么部署时甚至只需要:

app
data.db

无需安装:

  • MySQL
  • PostgreSQL
  • Redis

整个部署过程非常简单。

2. 性能并不差

很多人认为:

> "没有数据库服务器,性能会不会很低?"

实际上并不是。

由于嵌入式数据库:

  • 没有网络通信
  • 没有 Socket
  • 没有 TCP
  • 没有 SQL 解析(部分数据库)

很多简单读写场景反而更快。

特别是:

  • 配置读取
  • 缓存
  • 日志
  • 本地索引

性能往往非常优秀。

3. 更容易发布

很多开源项目都会提供:

Windows

Linux

macOS

三个版本。

如果依赖 MySQL。

用户还需要:

安装数据库

初始化

创建用户

导入 SQL

配置连接

而嵌入式数据库只需要:

下载

启动

开始使用

用户体验会好很多。

4. 数据天然本地化

很多桌面软件都会把数据保存在:

config.db

history.db

cache.db

复制数据库文件即可完成:

  • 备份
  • 迁移
  • 恢复

不需要额外导出 SQL。

有没有缺点?

当然有。

不适合高并发写入

虽然很多嵌入式数据库支持并发。

但对于:

  • 电商
  • 社交平台
  • 大型论坛

这种高并发业务。

仍然推荐:

  • MySQL
  • PostgreSQL

因为它们拥有更加成熟的事务管理。

不适合多台服务器共享

嵌入式数据库本质上还是一个本地文件。

例如:

server-a
    │
data.db

server-b
    │
data.db

两台服务器不能同时写同一个数据库文件。

因此:

分布式

主从同步

读写分离

这些能力通常需要额外实现。

哪些项目适合使用?

下面这些场景,其实都很适合。

  • 浏览器扩展
  • 桌面应用
  • Electron 项目
  • CLI 工具
  • NAS 应用
  • IoT 设备
  • 单机服务
  • 本地缓存
  • 配置中心
  • 日志系统

很多人每天都在使用 SQLite。

例如:

  • 微信
  • Chrome
  • Firefox
  • VS Code(部分数据)
  • Android
  • iOS

它们内部都有 SQLite 的身影。

Go 为什么喜欢嵌入式数据库?

近年来越来越多 Go 项目开始采用:

  • bbolt
  • BadgerDB
  • Pebble

原因很简单:

Go 推崇:

> 一个二进制文件完成部署。

如果数据库也采用嵌入式。

整个项目最终可能只需要:

app
config.yaml
data.db

部署体验非常优秀。

这也是很多个人开发者和开源项目喜欢它的重要原因。

> 选择数据库,不是追求"最强",而是找到最适合自己项目的方案。

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享
评论 抢沙发
头像-Cik
欢迎您留下宝贵的见解!
提交
头像-Cik

昵称

取消
昵称表情代码图片快捷回复

    暂无评论内容