加載鏡像
查詢官方鏡像及其版本信息
$ docker search redis
加載最新鏡像
$ docker pull redis:lastest
查看本地鏡像
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/redis latest f0453552d7f2 7 days ago 98.2 MB
docker.io/mysql latest 9b51d9275906 2 weeks ago 547 MB
docker.io/tomcat latest 4e7840b49fad 3 weeks ago 529 MB
運行容器
啟用daemon
$ docker run --name kris-redis -p 6380:6379 -d redis --requirepass "123456"
自定義redis.conf啟動
docker run -p 6379:6379 --name kris-redis -v /root/docker/redis/redis.conf:/etc/redis/redis.conf -v /root/docker/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes
# -p 6379:6379:把容器內的6379端口映射到宿主機6379端口
# -v /root/docker/redis/redis.conf:/etc/redis/redis.conf:把宿主機配置好的redis.conf放到容器內的這個位置中
# -v /root/docker/redis/data:/data:把redis持久化的數據在宿主機內顯示,做數據備份
# redis-server /etc/redis/redis.conf:這個是關鍵配置,讓redis不是無配置啟動,而是按照這個redis.conf的配置啟動
# -appendonly yes:redis啟動后數據持久化
查看運行狀態
$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3c90175b38e6 redis "docker-entrypoint..." 13 minutes ago Up 13 minutes 0.0.0.0:6380->6379/tcp kris-redis
2bbd52391bab mysql "docker-entrypoint..." 7 days ago Up 7 days 0.0.0.0:3306->3306/tcp, 33060/tcp kris-mysql
啟用redis-cli,即redis客戶端
$ docker exec -it kris-redis redis-cli
Redis五大數據類型
前言
Redis的關鍵字對大小寫不敏感,但不可以混合使用大小寫。
Redis存儲的形式是鍵值對。
Redis的五大數據類型:字符串、列表、集合、哈希、有序集合
Redis鍵
常用:
案例:
keys *
:返回所有"頂層key",即各大數據類型所存儲數據的名稱(注:Hash也是一個鍵值對,但Value也是一個鍵值對,<KEY, <K, V>>),舉個栗子:
127.0.0.1:6379>$ keys *
1) "customer" # 定義的Hash
2) "set01" # 定義的Set
3) "list01" # 定義的List
4) "username" # 定義的String
exists
:判斷某個key是否存在
127.0.0.1:6379>$ exists username
(integer) 1 # 存在返回1
127.0.0.1:6379>$ exists username00
(integer) 0 # 不存在返回0
move key dbindex
:當前庫(索引為:0)就沒有了,被移除了,數據被遷移到其他數據庫
注:redis.conf中默認有16個庫,默認為0,初始庫0是這樣的
127.0.0.1:6379>
,當選擇其他庫庫時,是這樣的127.0.0.1:6379[dbindex]>
dbindex表示庫的索引。
127.0.0.1:6379>$ move username 2 # 數據遷移至其他庫
(integer) 1 # 遷移成功
127.0.0.1:6379>$ select 2 # 選擇當前操作的數據庫
OK
127.0.0.1:6379[2]>$ get username # 查詢遷移后的數據,若查詢1庫中數據,需要重新選擇庫
"kris"
expire key 秒鍾
:為給定的key設置過期時間
ttl key
:查看還有多少秒過期,-1表示永不過期,-2表示已過期
127.0.0.1:6379[2]>$ expire username 10 # 存活10秒
127.0.0.1:6379[2]>$ ttl username
(integer) 7
127.0.0.1:6379[2]>$ ttl username
(integer) 2
127.0.0.1:6379[2]>$ ttl username
(integer) -2 # 已過期
127.0.0.1:6379[2]>$ get username
(nil) # 已經不存在了
type key
:查看你的key是什么類型
127.0.0.1:6379>$ type list01
list
字符串
概要:
- 字符串類型是redis最基礎的數據結構,首先鍵是字符串類型,而且其他幾種結構都是在字符串類型基礎上構建的,字符串類型是其他四種數據結構的基礎類型。
- 字符串類型實際上可以是字符串(簡單的字符串、復雜的字符串(xml、json)、數字(整數、浮點數)、二進制(圖片、音頻、視頻)),但最大不能超過512M。
使用場景:
- 緩存功能:字符串最經典的使用場景,redis作為緩存層,Mysql作為儲存層,絕大部分請求數據都是redis中獲取,由於redis具有支撐高並發特性,所以緩存通常能起到加速讀寫和降低后端壓力的作用。redis為何具備支撐高並發的特性? 。
- 計數器:許多運用都會使用redis作為計數的基礎工具,他可以實現快速計數、查詢緩存的功能,同時數據可以一步落地到其他的數據源。如:視頻播放數系統就是使用redis作為視頻播放數計數的基礎組件。
- 共享session:出於負載均衡的考慮,分布式服務會將用戶信息的訪問均衡到不同服務器上,用戶刷新一次訪問可能會需要重新登錄,為避免這個問題可以用redis將用戶session集中管理,在這種模式下只要保證redis的高可用和擴展性的,每次獲取用戶更新或查詢登錄信息都直接從redis中集中獲取。
- 限速:處於安全考慮,每次進行登錄時讓用戶輸入手機驗證碼,為了短信接口不被頻繁訪問,會限制用戶每分鍾獲取驗證碼的頻率。
常用命令:
案例:
set/get/del/append/strlen
定義時,如果已經存在,則會覆蓋保存
127.0.0.1:6379>$ set username kris
OK
127.0.0.1:6379>$ get username
"kris"
127.0.0.1:6379>$ append username louis
(integer) 9
127.0.0.1:6379>$ get username
"krislouis"
127.0.0.1:6379>$ strlen username
(integer) 9
列表
概要:
- 列表類型是用來儲存多個有序的字符串,列表中的每個字符串成為元素(element),一個列表最多可以儲存$2^{32}-1$個元素,在redis中,可以隊列表兩端插入(pubsh)和彈出(pop),還可以獲取指定范圍的元素 列表、獲取指定索引下表的元素等,列表是一種比較靈活的數據結構,它可以充當棧和隊列的角色,在實際開發中有很多應用場景。
- 優點:
1.列表的元素是有序的,這就意味着可以通過索引下標獲取某個或某個范圍內的元素列表。
2.列表內的元素是可以重復的。
使用場景:
-
消息隊列: redis的lpush+brpop命令組合即可實現阻塞隊列,生產者客戶端是用lupsh從列表左側插入元素,多個消費者客戶端使用brpop命令阻塞時的“搶”列表尾部的元素,多個客戶端保證了消費的負載均衡和高可用性。
-
使用列表技巧:
lpush+lpop=Stack(棧)
lpush+rpop=Queue(隊列)
lpush+ltrim=Capped Collection(有限集合)
lpush+brpop=Message Queue(消息隊列)
常用: 待更新
案例: 待更新
哈希
概要:
-
在redis中哈希類型是指鍵本身又是一種鍵值對結構,如 :
value={{field1,value1},......{fieldN,valueN}}
使用場景:
- 特性:哈希結構相對於字符串序列化緩存信息更加直觀,並且在更新操作上更加便捷。
- 常用於用戶信息等管理。
- 不足:哈希類型和關系型數據庫有所不同,哈希類型是稀疏的,而關系型數據庫是完全結構化的,易於實現復雜的關系查詢,redis是非關系型數據庫,需要模擬關系型數據庫進行復雜查詢,開發困難,維護成本高。
常用: 待更新
案例: 待更新
集合
概要:
- 集合類型也是用來保存多個字符串的元素,但和列表不同的是集合中不允許有重復的元素,並且集合中的元素是無序的,不能通過索引下標獲取元素,redis除了支持集合內的增刪改查,同時還支持多個集合取交集、並集、差集,並合理的使用好集合類型,能在實際開發中解決很多實際問題。
使用場景:
-
標簽(tag):集合類型比較典型的使用場景,如一個用戶對娛樂、體育比較感興趣,另一個可能對新聞感興趣,這些興趣就是標簽,有了這些數據就可以得到同一標簽的人,以及用戶的共同愛好的標簽,這些數據對於用戶體驗以及曾強用戶粘度比較重要。(用戶和標簽的關系維護應該放在一個事物內執行,防止部分命令失敗造成數據不一致)
sadd=tagging(標簽)
spop/srandmember=random item(生成隨機數,比如抽獎)
sadd+sinter=social Graph(社交需求)
常用: 待更新
案例: 待更新
有序集合
概要:
- 有序集合和集合有着必然的聯系,他保留了集合不能有重復成員的特性,但不同得是,有序集合中的元素是可以排序的,但是它和列表的使用索引下標作為排序依據不同的是,它給每個元素設置一個分數,作為排序的依據。(有序集合中的元素不可以重復,但是csore可以重復,就和一個班里的同學學號不能重復,但考試成績可以相同)。
使用場景:
排行榜:有序集合經典使用場景。
例如視頻網站需要對用戶上傳的視頻做排行榜,榜單維護可能是多方面:按照時間、按照播放量、按照獲得的贊數等。
常用: 待更新
案例: 待更新