redis的備份

来源:http://www.cnblogs.com/think-in-java/archive/2016/01/11/5121401.html
-Advertisement-
Play Games

瞭解redis的朋友應該知道它有兩種數據持久化的方式,這裡我作一個簡單的介紹,AOF(append only file)和RDB.1.RDB這是一種比較常見的方式,採用 寫時複製 的方式,效率高,速度快,介紹一下寫時複製的機制:當 Redis 需要保存 dump.rdb 文件時, 伺服器執行以下操作...


瞭解redis的朋友應該知道它有兩種數據持久化的方式,這裡我作一個簡單的介紹,AOF(append only  file)和RDB.

1.RDB

這是一種比較常見的方式,採用 寫時複製 的方式,效率高,速度快,介紹一下寫時複製的機制:

 

當 Redis 需要保存 dump.rdb 文件時, 伺服器執行以下操作:

 

  • Redis 調用 fork() ,同時擁有父進程和子進程。
  • 子進程將數據集寫入到一個臨時 RDB 文件中。
  • 當子進程完成對新 RDB 文件的寫入時,Redis 用新 RDB 文件替換原來的 RDB 文件,並刪除舊的 RDB 文件。

 

這種工作方式使得 Redis 可以從寫時複製(copy-on-write)機制中獲益。

 

這種機制使得RDB的速度非常得快,但是存在一些安全性問題,當我的redis服務因為某種原因宕了,當記憶體新增數據很龐大,子進程需要幾分鐘才能將臨時文件書寫完畢的時候。那麼在宕機之後,這幾分鐘的數據很可能就丟失了。所以處於安全性考慮的原因,我會建議使用第二種方式,AOF機制。

2.AOF

aof採用一種fsync的方式進行持久化,相比RDB的方式會相對較慢。但是相對安全,甚至可以說是絕對安全的,取決於具體的配置。他不需要子進程進行協助,他是一種將有關寫的命令append到文件的方式來記錄redis的狀態方式。aof也可以分為三種方式進行append。在此之前先打開appendonly的開關為yes.

     appendfsync always  (每次向記憶體中執行寫操作的時候,都執行一次fsync,相當安全,建議數據量不大的時候,又想保證數據安全性的情況下使用)

     appendfsync  everysec (每秒進行一次fsync,中庸之道)

     appendfsync no  (不建議使用)

 

我這裡例舉一下redis>2.2的由RDB切換到AOF的方式

[root@localhost redis-2.8.9]# redis-cli
127.0.0.1:6379> config set appendonly yes
OK
127.0.0.1:6379> config set save ""
OK
127.0.0.1:6379> 

redis-cli進入redisShell客戶端,然後開啟aof ,關閉RDB方式。

記得修改 redis.conf裡面的配置,不然下次重啟還是使用原來的配置,讀取dump.rdb進行恢復

配置修改如下:

   #save ""                                 save ""   
 
save 900 1                                  #save 900 1 
save 300 10            ------------------>  #save 300 10 
save 60 10000                               #save 60 10000

 

  appendonly no             --------------------->  appendonly yes

 

 

 

 

 

備份文件有兩種方式

一.RBD備份方式

1.執行save命令 ,找到dump.rdb(預設放到執行命令(redis-server)的路徑下)

2.執行redis-server  redis.conf (如果配置文件選擇的是RDB備份方式)

啟動之後就ok了

二.AOF備份方式

1.找到appendonly.aof(預設放到執行命令(redis-server)的路徑下)

 

2.執行redis-server redis.conf就可以了(如果配置文件選擇的是AOF備份方式)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概述 SQLite提供了一系列介面供用戶訪問資料庫,主要包括連接資料庫,處理SQL,迭代查詢結果等。本文會針對我們使用SQLite的主要場景,列出核心的API,詳細介紹API的用法並給出代碼用例。1.打開關閉資料庫sqlite3_open_v2原型:int sqlite3_open_v2(cons....
  • 本文轉至:http://database.51cto.com/art/201503/469510_all.htm(只作轉載, 不代表本站和博主同意文中觀點或證實文中信息)Olery成立於2010年,總部位於阿姆斯特丹。該初創公司為酒店行業提供聲譽管理與媒體監控工具,幫助酒店將網路評論和社交媒體反饋轉...
  • 本文轉載自:http://www.innomysql.net/article/23959.html(只作轉載, 不代表本站和博主同意文中觀點或證實文中信息)工作10餘年,沒有一個版本能像MySQL 5.7那樣令我激動與期盼,10月MySQL 5.7 GA版本的發佈,意味著MySQL資料庫終於有能力在...
  • ---------------原創內容,轉載請註明出處。------------一、概述RRDtool(round-robin database tool),即輪詢式資料庫工具(註:並不等同於電腦中的輪詢調度演算法),採用固定大小的空間來存儲數據,設定一個指針,隨數據的讀寫移動,指向最後更新的數據的...
  • 本文轉載自:http://www.oschina.net/translate/why-you-should-never-use-mongodb(只作轉載, 不代表本站和博主同意文中觀點或證實文中信息)免責聲明:我不構建資料庫引擎,但搭建Web應用。每年我大約跑4-6個不同項目,所以我搭建了不少Web...
  • 本文轉載自:http://www.innomysql.net/article/15612.html(只作轉載, 不代表本站和博主同意文中觀點或證實文中信息)前言上周參加了2015年的中國資料庫大會,差不多從第二屆開始就每年都會北京參會,從最早的嘉賓到這次的會場主持人,也算見證了中國資料庫大會的發展吧...
  • 在《基於Flume的美團日誌收集系統(一)架構和設計》中,我們詳述了基於Flume的美團日誌收集系統的架構設計,以及為什麼做這樣的設計。在本節中,我們將會講述在實際部署和使用過程中遇到的問題,對Flume的功能改進和對系統做的優化。1 Flume的問題總結在Flume的使用過程中,遇到的主要問題如下...
  • 美團的日誌收集系統負責美團的所有業務日誌的收集,並分別給Hadoop平臺提供離線數據和Storm平臺提供實時數據流。美團的日誌收集系統基於Flume設計和搭建而成。《基於Flume的美團日誌收集系統》將分兩部分給讀者呈現美團日誌收集系統的架構設計和實戰經驗。第一部分架構和設計,將主要著眼於日誌收集系...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...