用 C# 寫一個(gè) Redis 數(shù)據(jù)同步小工具

用 C# 寫一個(gè) Redis 數(shù)據(jù)同步小工具

Intro

為了實(shí)現(xiàn) redis 的數(shù)據(jù)遷移而寫的一個(gè)小工具,將一個(gè)實(shí)例中的 redis 數(shù)據(jù)同步到另外一個(gè)實(shí)例中。(原本打算找一個(gè)已有的工具去做,找了一個(gè) nodejs 的小工具,結(jié)果折騰了好久都沒裝上。。。于是就自己寫了這個(gè)小工具)

之所以自己寫一個(gè)工具而不是利用 redis 備份機(jī)制來實(shí)現(xiàn),主要是因?yàn)槲覀冇玫氖?redis 云服務(wù),不能像自己的服務(wù)器一樣 SSH 上去一頓操作,要把云服務(wù)的 redis 數(shù)據(jù)同步到自己服務(wù)器上的 redis 實(shí)例。

基本使用

配置解讀

{
  "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ù)庫(kù),多個(gè)數(shù)據(jù)庫(kù)用英文的逗號(hào)分隔
  • AppSettings:BatchSize 是每次從源 redis 服務(wù)器讀取 N 個(gè) key(分頁讀取,每頁 N 個(gè))
  • ConnectionStrings:Source 代表了源 redis 服務(wù)器連接字符串
  • ConnectionStrings:Dest 代表了目標(biāo) redis 服務(wù)器連接字符串

redis 連接字符串詳細(xì)參數(shù)可以參考文檔:https://weihanli.github.io/StackExchange.Redis-docs-zh-cn/Configuration.html

執(zhí)行遷移

修改 redis 配置之后(根據(jù)自己要同步數(shù)據(jù)量的大小設(shè)置超時(shí)時(shí)間),在項(xiàng)目根目錄下運(yùn)行 dotnet run 即可,

Sample Run

image

More

支持同步/遷移的數(shù)據(jù)類型:

  • String
  • Hash
  • List
  • Set
  • ZSet(SortedSet)

Reference

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容