Redis系列(一):小試牛刀

引言

隨著互聯網的高速發展,傳統的關係資料庫(如MySQL、Microsoft SQL Server等)已不能滿足日益增長的業務需求,如商品秒殺、搶購等及時性非常強的功能,隨著應用高並發的訪問,會造成系統資料庫崩潰,為了解決此種情況,需要引用一個快取中間件,市面上比較常用的快取中間件有Redis 和 Memcached,他們各自有自己的優缺點,但一般互聯網公司大都採用MySQL + Redis的方式進行架構,本文主要介紹Redis的概念及安裝配置。

簡介

概念

Redis(Remote Dictionary Server ) 是一個開源的使用 ANSI C 語言編寫、遵守 BSD 協議、支援網路、可基於記憶體亦可持久化的日誌型、Key-Value 資料庫,並提供多種語言的 API的非關係型資料庫。

傳統資料庫遵循 ACID 規則。而 Nosql(Not Only SQL 的縮寫,是對不同於傳統的關係型資料庫的資料庫管理系統的統稱) 一般為分散式而分散式一般遵循 CAP 定理。

它和Memcached類似,它支援存儲的value類型相對更多,包括string(字元串)、list(鏈表)、set(集合)、zset(sorted set –有序集合)和hash(哈希類型)。這些數據類型都支援push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。在此基礎上,redis支援各種不同方式的排序。與memcached一樣,為了保證效率,數據都是快取在記憶體中。區別的是Redis會周期性的把更新的數據寫入磁碟或者把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步,redis在3.0版本推出集群模式。

Github 源碼:https://github.com/antirez/redis

Redis 官網:https://redis.io/

特點、優勢

  • k、v鍵值存儲以及數據結構存儲(如列表、字典)
  • 所有數據(包括數據的存儲)操作均在記憶體中完成
  • 單執行緒服務(這意味著會有較多的阻塞情況),採用epoll模型進行請求響應,對比nginx
  • 支援主從複製模式,更提供高可用主從複製模式(哨兵)
  • 去中心化分散式集群
  • 豐富的編程介面支援,如Python、Golang、Java、php、Ruby、Lua、Node.js 
  • 功能豐富,除了支援多種數據結構之外,還支援事務、發布/訂閱、消息隊列等功能
  • 支援數據持久化(AOF、RDB)

對比memcache

  • memcache是一個分散式的記憶體對象快取系統,並不提供持久存儲功能,而redis擁有持久化功能
  • memcache數據存儲基於LRU(簡單說:最近、最少使用key會被剔除),而redis則可以永久保存(服務一直運行情況下)
  • memcache是多執行緒的(這是memcache優勢之一),也就意味著阻塞情況少,而redis是單執行緒的,阻塞情況相對較多
  • 兩者性能上相差不大
  • memcache只支援簡單的k、v數據存儲,而redis支援多種數據格式存儲。
  • memcache是多執行緒、非阻塞IO復用網路模型,而redis是單執行緒IO復用模型

安裝Windows版本

Redis的windoms版下載地址:https://github.com/microsoftarchive/redis/releases

下載自己需要的版本,如下圖(msi是安裝版本,zip是解壓版):

下載zip到本地解壓(筆者解壓目錄為D:Program FilesRedis),目錄如下:

開啟服務,運行CMD,切換到解壓目錄,執行如下命令(並設置最大記憶體):

redis-server.exe redis.windows.conf --maxmemory 200M

效果如圖所示:

開啟命令行客戶端,執行如下命令:

redis-cli.exe

添加和查詢Key-Value,執行如下命令:

#設置鍵值  set key value  #獲取鍵值  get key

查詢和設置密碼,執行如下命令:

#查詢密碼  config get requirepass  #設置密碼  config set requirepass 密碼

輸入密碼,執行如下命令:

auth 密碼

以上幾個命令,演示如下圖所示。

 註冊和卸載服務,執行如下命令:

#註冊安裝服務  redis-server --service-install redis.windows.conf --loglevel verbose  #卸載服務  #redis-server --service-uninstall

執行效果,如下圖:

 註冊完成後,可以在電腦服務中看到該服務,如下圖所示。

 

 開啟服務後,可以直接用命令行客戶端進行連接。

 總結

本文簡單的介紹了Redis的背景、概念及Windows版本的安裝及測試,在後續博文中,將繼續講解Redis的相關內容,如果本文對你有所幫助,就是我寫作的動力!感興趣的朋友可以加關注,歡迎留言交流!