用 C# 写一个 Redis 数据同步小工具
用 C# 寫一個 Redis 數(shù)據(jù)同步小工具
Intro
為了實現(xiàn) redis 的數(shù)據(jù)遷移而寫的一個小工具,將一個實例中的 redis 數(shù)據(jù)同步到另外一個實例中。(原本打算找一個已有的工具去做,找了一個 nodejs 的小工具,結(jié)果折騰了好久都沒裝上。。。于是就自己寫了這個小工具)
之所以自己寫一個工具而不是利用 redis 備份機制來實現(xiàn),主要是因為我們用的是 redis 云服務,不能像自己的服務器一樣 SSH 上去一頓操作,要把云服務的 redis 數(shù)據(jù)同步到自己服務器上的 redis 實例。
基本使用
配置解讀
{"AppSettings": {"SyncDatabases": "0,1","BatchSize": 50},"ConnectionStrings": {"Source": "redis1:6379,asyncTimeout=30000,syncTimeout=30000","Dest": "redis2:6379,password=123433,asyncTimeout=30000,syncTimeout=30000"} }AppSettings:SyncDatabases是要同步的 redis 數(shù)據(jù)庫,多個數(shù)據(jù)庫用英文的逗號分隔
AppSettings:BatchSize?是每次從源 redis 服務器讀取 N 個 key(分頁讀取,每頁 N 個)
ConnectionStrings:Source?代表了源 redis 服務器連接字符串
ConnectionStrings:Dest?代表了目標 redis 服務器連接字符串
redis 連接字符串詳細參數(shù)可以參考文檔:https://weihanli.github.io/StackExchange.Redis-docs-zh-cn/Configuration.html
執(zhí)行遷移
修改 redis 配置之后(根據(jù)自己要同步數(shù)據(jù)量的大小設置超時時間),在項目根目錄下運行 dotnet run 即可,
Sample Run
More
支持同步/遷移的數(shù)據(jù)類型:
String
Hash
List
Set
ZSet(SortedSet)
實現(xiàn)源碼:https://github.com/WeihanLi/SamplesInPractice/tree/master/RedisCopy
Reference
https://github.com/WeihanLi/SamplesInPractice/tree/master/RedisCopy
https://weihanli.github.io/StackExchange.Redis-docs-zh-cn/Configuration.html
總結(jié)
以上是生活随笔為你收集整理的用 C# 写一个 Redis 数据同步小工具的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 腾飞答不忘初心的三个问题
- 下一篇: C#如何安全、高效地玩转任何种类的内存之