🌱 Rudis 0.0.1 发布,一个高性能内存数据库
项目介绍
Rudis 是一个高性能内存数据库。
Rudis 是采用 Rust 语言开发的项目,旨在利用 Rust 语言的优势来重新实现 Redis 的核心功能,以满足用户对高性能、可靠性和安全性的需求,同时保持与 Redis API 的兼容。
项目地址
Gitee:https://gitee.com/Jmysy/rudis
Github:https://github.com/sleeprite/rudis
备注:release 目录,发行包
官网前瞻
项目特性
-
跨平台,兼容 windows、linux 系统架构。
-
兼容 字符串、集合、哈希、列表、等结构。
-
提供 rdb 与 aof 机制以支持数据备份和恢复。
-
兼容 Redis 的命令和协议规范。
-
内置 40+ 操作命令。
快速入门
参数启动
start rudis-server.exe --port 6379
指定配置
start rudis-server.exe rudis-server.properties
启动成功
启动参数
- port 端口, 默认: 6379
- save RDB 保存策略, 默认:none
- password 密码, 默认:none
- databases 数据库数量, 默认:16
- appendfilename 持久化日志路径
- appendonly 开启持久化,默认:false
- dbfilename 数据文件名,默认:dump.rdb
- maxclients 会话上限,默认 1000
- hz 定时任务的频率,默认 10(次/秒)
- dir 数据持久化目录,默认 "./"
- bind 绑定的主机地址
项目结构
command
command 包是一个用Rust编写的模拟Redis服务器的组件,主要负责实现Redis协议的解析、数据库操作的执行以及相关结果的响应。该包内部包含了针对不同Redis命令的实现,如SELECT、GET、SET等。其核心功能是根据Redis协议规范,解析来自客户端的命令请求,并在模拟的Redis数据库上执行相应的操作,再将结果返回给客户端。通过实现各个Redis命令处理器,实现了对Redis协议的完整支持,并提供了一个简单而有效的策略来处理不同类型的命令。
db
db 包是一个基于内存的数据库管理系统。该模块提供了基础的数据结构约定,以及数据库操作功能,包括对数据的增、删、改、查等操作。
Persistence
persistence 包实现了 AOF 和 RDB 的核心逻辑,该包负责将操作写入和追加到 AOF 文件中,以及 dump.rdb 文件,确保 Redis 数据库的数据持久性和一致性。
session
session 模块的设计目的是提供一个简单的会话管理功能,用于跟踪用户的操作状态,例如用户所选的数据库索引以及用户是否已认证等信息。这对于需要进行用户认证或者跟踪用户操作状态的系统是非常有用的。
tools
tools 包是一个工具包,其中包含了一些通用的工具函数或工具类,用于辅助实现系统功能或处理特定任务。这些工具可以被其他模块或组件调用,以提高代码复用性和降低重复编写相似功能的工作量。
常用命令
你可以前往 README.md 查看所有命令
echo 命令
127.0.0.1:6379> echo helloword helloword
ping 命令
127.0.0.1:6379> ping PONG
set 命令
127.0.0.1:6379> set user bailiang OK
set 命令 [过期]
127.0.0.1:6379> set user bailiang px 10000 OK 127.0.0.1:6379> set user bailiang ex 10 OK
get 命令
127.0.0.1:6379> get user bailiang
del 命令
127.0.0.1:6379> del username (integer) 1 127.0.0.1:6379> del username password (integer) 2
exists 命令
127.0.0.1:6379> exists user (integer) 0
keys 命令
127.0.0.1:6379> keys * (empty list or set)
auth 命令
127.0.0.1:6379> auth 123456 OK
expire 命令
127.0.0.1:6379> expire user 10000 (integer) 0
select 命令
127.0.0.1:6379> select 1 OK
dbsize 命令
127.0.0.1:6379> dbsize (integer) 2
flushdb 命令
127.0.0.1:6379> flushdb OK
flushall 命令
127.0.0.1:6379> flushall OK
append 命令
127.0.0.1:6379> append user bailiang (integer) 10
move 命令
127.0.0.1:6379> move user 0 OK
rename 命令
127.0.0.1:6379> rename username new_username OK
rpush 命令
127.0.0.1:6379> rpush key value1 value2 OK
lpush 命令
127.0.0.1:6379> lpush key value3 value4 OK
llen 命令
127.0.0.1:6379> llen key (integer) 4

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
RuleGo v0.22.0 发布:Go 轻量级、高性能、嵌入式、组件编排新一代规则引擎
首先祝贺RuleGo获得“Gitee 2024最有价值开源项目“奖项(GVP),感谢Gitee评审团队的认可。 RuleGo 是一个基于 Go 语言的轻量级、高性能、嵌入式、组件编排新一代规则引擎。支持异构系统数据集成、系统联动、业务逻辑动态编排,可以对输入消息进行聚合、分发、过滤、转换、丰富和执行各种动作。 典型使用场景 边缘计算: 可以在边缘服务器部署 RuleGo,对数据进行预处理,筛选、聚合或者计算后再上报到云端。数据的处理规则和分发规则可以通过规则链动态配置和修改,而不需要重启系统。国产替代node-red系统。 物联网: 收集设备数据上报,经过规则链的规则判断,触发一个或者多个动作,例如:发邮件、发告警、和其他设备或者系统联动。 数据分发: 可以根据不同的消息类型,调用 HTTP、MQTT 或者 gRPC 把数据分发到不同系统。 应用集成: 把 RuleGo 当做胶水连接各种系统或者协议,例如:ssh、webhook、kafka、消息队列、数据库、chatGPT、第三方应用系统。 异构系统数据集中处理: 从不同的数据源(如 MQTT、HTTP、WS、TCP/UDP 等)接收...
- 下一篇
开源可视化报表,JimuReport 积木报表 v1.7.7 版本发布
项目介绍 一款免费的数据可视化报表工具,含报表和大屏设计,像搭建积木一样在线设计报表!功能涵盖,数据报表、打印设计、图表报表、大屏设计等! Web 版报表设计器,类似于 excel 操作风格,通过拖拽完成报表设计。 秉承 "简单、易用、专业" 的产品理念,极大的降低报表开发难度、缩短开发周期、节省成本、解决各类报表难题。 领先的企业级 Web 报表,采用纯 Web 在线技术,专注于解决企业报表快速制作难题。 当前版本:v1.7.7 | 2024-07-08 集成依赖 springboot2 版本 <dependency> <groupId>org.jeecgframework.jimureport</groupId> <artifactId>jimureport-spring-boot-starter</artifactId> <version>1.7.7</version> </dependency> springboot3 版本 <dependency> ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- MySQL8.0.19开启GTID主从同步CentOS8