rqlite:一个基于SQLite构建的分布式数据库

今天给大家介绍一个基于 SQLite 构建的轻量级分布式关系型数据库:rqlite

rqlite 基于 Raft 协议,结合了 SQLite 的简洁性以及高可用分布式系统的稳健性,对开发者友好,操作极其简便,其核心设计理念是以最低的复杂度实现高可靠性。

核心特性

rqlite 提供了以下关键特性:

  • 部署简单:秒级部署,没有任何复杂配置。
  • 开发友好:简单易用的 HTTP APICLI 以及客户端驱动。
  • 功能强大:基于 SQLite,支持权威检索、JSON 以及各种插件(向量搜索、sqlean)。
  • 大量数据: 支持 GB 级别的数据管理。
  • 高可靠性:通过复制实现容错性和高可用。
  • 动态集群:集成 KubernetesConsuletcd 以及 DNS,实现自动集群管理。
  • 安全性强:支持各种加密和 TLS 安全传输。
  • 灵活一致性:可配置的读一致性和持久性。
  • 可扩展读:通过只读节提高读取性能。
  • 事务支持:HTTP API 支持事务语句。
  • 备份恢复:支持节点热备,压缩备份;自动备份到 AWS S3 以及 MinIO;支持从 SQLite 数据库文件恢复。
  • 监控信息:提供诊断和统计信息,节点状态信息,可读性检查等。

下载安装

rqlite 支持 LinuxmacOS 以及 Windows,最简单安装方法的是下载二进制安装文件:

https://github.com/rqlite/rqlite/releases

选择对应操作系统的文件进行解压,然后执行以下命令运行单节点:

bash 复制代码
./rqlited -node-id=1 data/

其中,-node-id 指定了节点编号, data/ 是数据存储目录。服务启动后的监听地址为 http://localhost:4001

接下来使用客户端工具 rqlite shell 连接数据库并执行 SQL 语句:

bash 复制代码
$ rqlite
127.0.0.1:4001>CREATETABLE foo (id INTEGERNOTNULLPRIMARYKEY, name TEXT)
1row affected (0.000668 sec)
127.0.0.1:4001>.schema
+-----------------------------------------------------------------------------+
|sql                                                                         |
+-----------------------------------------------------------------------------+
|CREATETABLE foo (id INTEGERNOTNULLPRIMARYKEY, name TEXT)               |
+-----------------------------------------------------------------------------+
127.0.0.1:4001>INSERTINTO foo(name)VALUES("fiona")
1row affected
127.0.0.1:4001>SELECT*FROM foo
+----+-------+
| id | name  |
+----+-------+
|1| fiona |
+----+-------+

如果想要创建一个分布式 rqlite 集群,可以启动其他节点服务:

bash 复制代码
./rqlited -node-id 2 -http-addr localhost:4003 -raft-addr localhost:4004 -join localhost:4002 data2/

./rqlited -node-id 3 -http-addr localhost:4005 -raft-addr localhost:4006 -join localhost:4002 data3/

我们在同一个主机上启动了另外两个服务,分别使用了不同的节点编号和监听地址,同时加入了第一个节点集群。

然后在客户端中查看集群状态:

bash 复制代码
127.0.0.1:4001> .nodes
1:
  api_addr: http://localhost:4001
  addr: localhost:4002
  voter: true
  reachable: true
  leader: true
  id: 1
2:
  api_addr: http://localhost:4003
  addr: localhost:4004
  voter: true
  reachable: true
  leader: false
  id: 2
3:
  api_addr: http://localhost:4005
  addr: localhost:4006
  voter: true
  reachable: true
  leader: false
  id: 3

其中,第一个节点是 leader。此时,我们获得了一个分布式集群数据库,任何数据操作都会复制到其他节点。

官方网址:https://rqlite.io/

官方文档:https://rqlite.io/docs/

相关推荐
GreatSQL7 分钟前
GreatSQL备份报错"PROCESS权限不足"分析与解决
数据库
言笑非11 分钟前
ClickHouse物化视图
数据库
专注VB编程开发20年1 小时前
C#教程之NPOI读写excel文件XLS,XLSX格式
数据库·microsoft·c#·excel·xlsx·xls
winfield8211 小时前
间隙锁(Gap Lock)
数据库·mysql
博一波3 小时前
【车联网kafka】Kafka核心架构与实战经验(第三篇)
分布式·架构·kafka
TDengine (老段)11 小时前
TDengine IDMP 快速体验(方式二 通过 docker)
大数据·数据库·docker·ai·时序数据库·tdengine·涛思数据
CANI_PLUS12 小时前
ESP32将DHT11温湿度传感器采集的数据上传到XAMPP的MySQL数据库
android·数据库·mysql
掘金-我是哪吒14 小时前
分布式微服务系统架构第163集:哈罗电池设备Netty网关架构
分布式·微服务·云原生·架构·系统架构
国王不在家15 小时前
3.5-非关系型数据库-反规范化-sql语言
数据库·nosql
Code季风17 小时前
如果缓存和数据库更新失败,如何实现最终一致性?
数据库·分布式·缓存·微服务·性能优化