## 概述
Rudis 是一個高性能內存數據庫。Rudis 是采用 Rust 語言開發的項目,旨在利用 Rust 語言的優勢來重新實現 Redis 的核心功能,以滿足用戶對高性能、可靠性和安全性的需求,同時保持與 Redis API 的兼容。
## 特性
- 兼容 字符串、集合、哈希、列表、有序集合數據結構。
- 提供 rdb 與 aof 機制以支持數據備份和恢復。
- 兼容 Redis 的命令和協議規范
## 快速入門
- 啟動畫面
```
/\_____/\
/ o o \ Rudis 0.0.1
( == ^ == )
) ( Bind: 127.0.0.1:6379
( )
( ( ) ( ) )
(__(__)___(__)__)
[2024-04-30T02:00:55Z INFO rudis_server] Start loading appendfile
[=======================================] percent: 100% lines: 6/6
[2024-04-30T02:00:55Z INFO rudis_server] Server initialized
[2024-04-30T02:00:55Z INFO rudis_server] Ready to accept connections
```
- 本地調試
```
// 普通啟動
cargo run
// 帶參啟動
cargo run -- --port 8848
// 指定配置
cargo run -- rudis.properties
// 構建程序
cargo build
cargo build --release
cargo build --release --target=x86_64-unknown-linux-musl
```
## 啟動參數
- port 端口, 默認: 6379
- save RDB 保存策略, 默認:None
- password 密碼, 默認:None
- databases 數據庫數量, 默認:16
- appendfilename 持久化日志路徑,默認:None
- appendonly 開啟持久化,默認:false
- dbfilename 數據文件名,默認:dump.rdb
- maxclients 會話上限,默認 1000
- hz 定時任務的頻率,默認 10(次/秒)
- dir 數據持久化目錄,默認 "./"
- bind 綁定的主機地址
## 項目結構
### aof
aof 包實現了 appendonlyfile 的核心邏輯,該包負責將操作寫入和追加到 AOF 文件中,確保 Redis 數據庫的數據持久性和一致性。
### command
command 包是一個用Rust編寫的模擬Redis服務器的組件,主要負責實現Redis協議的解析、數據庫操作的執行以及相關結果的響應。該包內部包含了針對不同Redis命令的實現,如SELECT、GET、SET等。其核心功能是根據Redis協議規范,解析來自客戶端的命令請求,并在模擬的Redis數據庫上執行相應的操作,再將結果返回給客戶端。通過實現各個Redis命令處理器,實現了對Redis協議的完整支持,并提供了一個簡單而有效的策略來處理不同類型的命令。
### db
db 包是一個基于內存的數據庫管理系統。該模塊提供了基礎的數據結構約定,以及數據庫操作功能,包括對數據的增、刪、改、查等操作。
### session
session 模塊的設計目的是提供一個簡單的會話管理功能,用于跟蹤用戶的操作狀態,例如用戶所選的數據庫索引以及用戶是否已認證等信息。這對于需要進行用戶認證或者跟蹤用戶操作狀態的系統是非常有用的。
### tools
tools 包是一個工具包,其中包含了一些通用的工具函數或工具類,用于輔助實現系統功能或處理特定任務。這些工具可以被其他模塊或組件調用,以提高代碼復用性和降低重復編寫相似功能的工作量。
## 操作命令
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
```
## 更新計劃
- [x] 持久存儲,存儲每條修改命令到本地文件,啟動時重新加載實現持久化存儲;
- [x] 日志體系,完善系統中日志打印,制訂規范,幫助使用者更快速的追溯問題;
- [x] 測試用例,針對項目中的每個命令,編寫對應的單元測試,提高項目穩定性;
- [ ] 性能優化,使用 Tokio 代替原生的 Thread 通訊方案,以獲得更高的性能;
- [ ] 主從同步,增加主從同步配置,實現多實例運行,以保證服務的容錯與穩定;
- [ ] 測試用例,根據 commands 清單,編寫軟件的單元測試用例,保證穩健發布;
## 數據結構
- [x] List
- [x] Hash
- [x] Zset
- [x] String
- [x] Set
## 命令列表
| Command | Supprt | Appendfile | Test case | Document |
| ------- | ------ | ---------- | --------- |--------- |
| set | ? | ? | ? | ? |
| get | ? | ? | ? | ? |
| del | ? | ? | ? | ? |
| echo | ? | ? | ? | ? |
| flushdb | ? | ? | ? | ? |
| flushall| ? | ? | ? | ? |
| dbsize | ? | ? | ? | ? |
| auth | ? | ? | ? | ? |
| select | ? | ? | ? | ? |
| llen | ? | ? | ? | ? |
| exists | ? | ? | ? | ? |
| expire | ? | ? | ? | ? |
| rename | ? | ? | ? | ? |
| move | ? | ? | ? | ? |
| lpush | ? | ? | ? | ? |
| rpush | ? | ? | ? | ? |
| append | ? | ? | ? | ? |
| incr | ? | ? | ? | ? |
| decr | ? | ? | ? | ? |
| lindex | ? | ? | ? | ? |
| lpop | ? | ? | ? | ? |
| rpop | ? | ? | ? | ? |
| lrange | ? | ? | ? | ? |
| ttl | ? | ? | ? | ? |
| pttl | ? | ? | ? | ? |
| type | ? | ? | ? | ? |
| sadd | ? | ? | ? | ? |
| smembers| ? | ? | ? | ? |
| scard | ? | ? | ? | ? |
| hmset | ? | ? | ? | ? |
| hget | ? | ? | ? | ? |
| hdel | ? | ? | ? | ? |
| hexists | ? | ? | ? | ? |
| hset | ? | ? | ? | ? |
| keys | ? | ? | ? | ? |
| zadd | ? | ? | ? | ? |
| zscore | ? | ? | ? | ? |
| zcard | ? | ? | ? | ? |
| zcount | ? | ? | ? | ? |
| pexpire | ? | ? | ? | ? |
| mset | ? | ? | ? | ? |
## 性能測試
- percent: 100% lines: 100000/100000 time: 00:00:04
- percent: 100% lines: 200000/200000 time: 00:00:09
- percent: 100% lines: 400000/400000 time: 00:00:19
- 設計模式系列
- 工廠方法模式
- 序言
- Windows程序注冊為服務的工具WinSW
- 基礎
- 安裝
- 開發規范
- 目錄結構
- 配置
- 快速入門
- 架構
- 請求流程
- 架構總覽
- URL訪問
- 容器和依賴注入
- 中間件
- 事件
- 代碼層結構
- 四個層次
- 路由
- 控制器
- 請求
- 響應
- 數據庫
- MySQL實時同步數據到ES解決方案
- 阿里云DTS數據MySQL同步至Elasticsearch實戰
- PHP中的MySQL連接池
- PHP異步非阻塞MySQL客戶端連接池
- 模型
- 視圖
- 注解
- @SpringBootApplication(exclude={DataSourceAutoConfiguration.calss})
- @EnableFeignClients(basePackages = "com.wotu.feign")
- @EnableAspectJAutoProxy
- @EnableDiscoveryClient
- 錯誤和日志
- 異常處理
- 日志處理
- 調試
- 驗證
- 驗證器
- 驗證規則
- 擴展庫
- 附錄
- Spring框架知識體系詳解
- Maven
- Maven和Composer
- 構建Maven項目
- 實操課程
- 01.初識SpringBoot
- 第1章 Java Web發展史與學習Java的方法
- 第2章 環境與常見問題踩坑
- 第3章 springboot的路由與控制器
- 02.Java編程思想深度理論知識
- 第1章 Java編程思想總體
- 第2章 英雄聯盟的小案例理解Java中最為抽象的概念
- 第3章 徹底理解IOC、DI與DIP
- 03.Spring與SpringBoot理論篇
- 第1章 Spring與SpringBoot導學
- 第2章 Spring IOC的核心機制:實例化與注入
- 第3章 SpringBoot基本配置原理
- 04.SprinBoot的條件注解與配置
- 第1章 conditonal 條件注解
- 第2章 SpringBoot自動裝配解析
- 05.Java異常深度剖析
- 第1章 Java異常分類剖析與自定義異常
- 第2章 自動配置Url前綴
- 06.參數校驗機制與LomBok工具集的使用
- 第1章 LomBok工具集的使用
- 第2章 參數校驗機制以及自定義校驗
- 07.項目分層設計與JPA技術
- 第1章 項目分層原則與層與層的松耦合原則
- 第2章 數據庫設計、實體關系與查詢方案探討
- 第3章 JPA的關聯關系與規則查詢
- 08.ORM的概念與思維
- 第1章 ORM的概念與思維
- 第2章 Banner等相關業務
- 第3章 再談數據庫設計技巧與VO層對象的技巧
- 09.JPA的多種查詢規則
- 第1章 DozerBeanMapper的使用
- 第2章 詳解SKU的規格設計
- 第3章 通用泛型Converter
- 10.令牌與權限
- 第1章 通用泛型類與java泛型的思考
- 常見問題
- 微服務
- demo
- PHP中Self、Static和parent的區別
- Swoole-Cli
- 為什么要使用現代化PHP框架?
- 公眾號
- 一鍵部署微信公眾號Markdown編輯器(支持適配和主題設計)
- Autodesigner 2.0發布
- Luya 一個現代化PHP開發框架
- PHPZip - 創建、讀取和管理 ZIP 文件的簡單庫
- 吊打Golang的PHP界天花板webman壓測對比
- 簡潔而強大的 YAML 解析庫
- 推薦一個革命性的PHP測試框架:Kahlan
- ServBay下一代Web開發環境
- 基于Websocket和Canvas實現多人協作實時共享白板
- Apipost預執行腳本如何調用外部PHP語言
- 認證和授權的安全令牌 Bearer Token
- Laradock PHP 的 Docker 完整本地開發環境
- 高效接口防抖策略,確保數據安全,避免重復提交的終極解決方案!
- TIOBE 6月榜單:PHP穩步前行,編程語言生態的微妙變化
- Aho-Corasick字符串匹配算法的實現
- Redis鍵空間通知 Keyspace Notification 事件訂閱
- ServBay如何啟用并運行Webman項目
- 使用mpdf實現導出pdf文件功能
- Medoo 輕量級PHP數據庫框架
- 在PHP中編寫和運行單元測試
- 9 PHP運行時基準性能測試
- QR碼生成器在PHP中的源代碼
- 使用Gogs極易搭建的自助Git服務
- Gitea
- webman如何記錄SQL到日志?
- Sentry PHP: 實時監測并處理PHP應用程序中的錯誤
- Swoole v6 Alpha 版本已發布
- Proxypin
- Rust實現的Redis內存數據庫發布
- PHP 8.4.0 Alpha 1 測試版本發布
- 121
- Golang + Vue 開發的開源輕量 Linux 服務器運維管理面板
- 內網穿透 FRP VS Tailscale
- 新一代開源代碼托管平臺Gitea
- 微服務系列
- Nacos云原生配置中心介紹與使用
- 輕量級的開源高性能事件庫libevent
- 國密算法
- 國密算法(商用密碼)
- GmSSL 支持國密SM2/SM3/SM4/SM9/SSL 密碼工具箱
- GmSSL PHP 使用
- 數據庫
- SQLite數據庫的Web管理工具
- 阿里巴巴MySQL數據庫強制規范
- PHP
- PHP安全測試秘密武器 PHPGGC
- 使用declare(strict_types=1)來獲得更健壯的PHP代碼
- PHP中的魔術常量
- OSS 直傳阿里騰訊示例
- PHP源碼編譯安裝APCu擴展實現數據緩存
- BI性能DuckDB數據管理系統
- 為什么別人可以是架構師!而我卻不是?
- 密碼還在用 MD5 加鹽?不如試試 password_hash
- Elasticsearch 在電商領域的應用與實踐
- Cron 定時任務入門
- 如何動態設置定時任務!而不是寫死在Linux Crontab
- Elasticsearch的四種查詢方式,你知道多少?
- Meilisearch vs Elasticsearch
- OpenSearch vs Elasticsearch
- Emlog 輕量級開源博客及建站系統
- 現代化PHP原生協程引擎 PRipple
- 使用Zephir編寫C擴展將PHP源代碼編譯加密
- 如何將PHP源代碼編譯加密,同時保證代碼能正常的運行
- 為什么選擇Zephir給PHP編寫動態擴展庫?
- 使用 PHP + XlsWriter實現百萬級數據導入導出
- Rust編寫PHP擴展
- 阿里云盤開放平臺對接進行文件同步
- 如何構建自己的PHP靜態可執行文件
- IM后端架構
- RESTful設計方法和規范
- PHP編譯器BPC 7.3 發布,成功編譯ThinkPHP8
- 高性能的配置管理擴展 Yaconf
- PHP實現雪花算法庫 Snowflake
- PHP官方現代化核心加密庫Sodium
- pie
- 現代化、精簡、非阻塞PHP標準庫PSL
- PHP泛型和集合
- 手把手教你正確使用 Composer包管理
- JWT雙令牌認證實現無感Token自動續期
- 最先進PHP大模型深度學習庫TransformersPHP
- PHP如何啟用 FFI 擴展
- PHP超集語言PXP
- 低延遲雙向實時事件通信 Socket.IO
- PHP OOP中的繼承和多態
- 強大的現代PHP高級調試工具Kint
- PHP基金會
- 基于webman+vue3高質量中后臺框架SaiAdmin
- 開源免費的定時任務管理系統:Gocron
- 簡單強大OCR工具EasyOCR在PHP中使用
- PHP代碼抽象語法樹工具PHP AST Viewer
- MySQL數據庫管理工具PHPMyAdmin
- Rust編寫的一款高性能多人代碼編輯器Zed
- 超高性能PHP框架Workerman v5.0.0-beta.8 發布
- 高并發系列
- 入門介紹及安裝
- Lua腳本開發 Hello World
- 執行流程與階段詳解
- Nginx Lua API 接口開發
- Lua模塊開發
- OpenResty 高性能的正式原因
- 記一次查找 lua-resty-mysql 庫 insert_id 的 bug
- 包管理工具OPM和LuaRocks使用
- 異步非阻塞HTTP客戶端庫 lua-resty-http
- Nginx 內置綁定變量
- Redis協程網絡庫 lua-resty-redis
- 動態HTML渲染庫 lua-testy-template
- 單獨的
- StackBlitz在線開發環境
- AI
- 基礎概念
- 12312
- 基礎鏡像的坑
- 利用phpy實現 PHP 編寫 Vision Transformer (ViT) 模型
- 語義化版本 2.0.0