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 Files\Redis),目錄如下:

開啓服務,運行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的相關內容,如果本文對你有所幫助,就是我寫作的動力!感興趣的朋友可以加關注,歡迎留言交流! 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章