查询官方镜像及其版本信息mysql
$ docker search redis
加载最新镜像redis
$ docker pull redis:lastest
查看本地镜像sql
$ 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
启用daemondocker
$ docker run --name kris-redis -p 6380:6379 -d redis --requirepass "123456"
自定义redis.conf启动shell
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客户端json
$ docker exec -it kris-redis redis-cli
Redis的关键字对大小写不敏感,但不能够混合使用大小写。后端
Redis存储的形式是键值对。缓存
Redis的五大数据类型:字符串、列表、集合、哈希、有序集合tomcat
经常使用:
案例:
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
概要:
使用场景:
经常使用命令:
案例:
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
概要:
使用场景:
消息队列: 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}}
使用场景:
经常使用: 待更新
案例: 待更新
概要:
使用场景:
标签(tag):集合类型比较典型的使用场景,如一个用户对娱乐、体育比较感兴趣,另外一个可能对新闻感兴趣,这些兴趣就是标签,有了这些数据就能够获得同一标签的人,以及用户的共同爱好的标签,这些数据对于用户体验以及曾强用户粘度比较重要。(用户和标签的关系维护应该放在一个事物内执行,防止部分命令失败形成数据不一致)
sadd=tagging(标签) spop/srandmember=random item(生成随机数,好比抽奖) sadd+sinter=social Graph(社交需求)
经常使用: 待更新
案例: 待更新
概要:
使用场景:
排行榜:有序集合经典使用场景。
例如视频网站须要对用户上传的视频作排行榜,榜单维护多是多方面:按照时间、按照播放量、按照得到的赞数等。
经常使用: 待更新
案例: 待更新