博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis从入门到精通
阅读量:5729 次
发布时间:2019-06-18

本文共 10012 字,大约阅读时间需要 33 分钟。

解压后的安装

[root@server1 redis-3.0.5]# make

指定安装目录:

[root@server1 redis-3.0.5]# make PREFIX=/usr/local/redis install

进入/usr/local/redis里面:

[root@server1 redis]# lsbin[root@server1 redis]# cd bin[root@server1 bin]# lsredis-benchmark  redis-check-aof  redis-check-dump  redis-cli  redis-sentinel  redis-server复制代码
[root@server1 bin]# cp /root/redis-3.0.5/redis.conf  redis.conf复制代码

启动:

[root@server1 bin]# ./redis-server redis.conf复制代码

出现:

_._                                                             _.-``__ ''-._                                                   _.-``    `.  `_.  ''-._           Redis 3.0.5 (00000000/0) 64 bit  .-`` .-```.  ```\/    _.,_ ''-._                                    (    '      ,       .-`  | `,    )     Running in standalone mode |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379 |    `-._   `._    /     _.-'    |     PID: 23880  `-._    `-._  `-./  _.-'    _.-'                                    |`-._`-._    `-.__.-'    _.-'_.-'|                                   |    `-._`-._        _.-'_.-'    |           http://redis.io          `-._    `-._`-.__.-'_.-'    _.-'                                    |`-._`-._    `-.__.-'    _.-'_.-'|                                   |    `-._`-._        _.-'_.-'    |                                    `-._    `-._`-.__.-'_.-'    _.-'                                         `-._    `-.__.-'    _.-'                                                 `-._        _.-'                                                         `-.__.-'                                               23880:M 12 Mar 22:33:16.711 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.23880:M 12 Mar 22:33:16.711 # Server started, Redis version 3.0.523880:M 12 Mar 22:33:16.711 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.23880:M 12 Mar 22:33:16.711 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.23880:M 12 Mar 22:33:16.712 * The server is now ready to accept connections on port 6379复制代码

这只是前台启动,关闭终端自动停止。

新建一个窗口,进入终端命令:

[root@server1 ~]# cd /usr/local/redis[root@server1 redis]# lsbin[root@server1 redis]# cd bin[root@server1 bin]# lsredis-benchmark  redis-check-dump  redis.conf      redis-serverredis-check-aof  redis-cli         redis-sentinel[root@server1 bin]#  ./redis-cli127.0.0.1:6379> 127.0.0.1:6379> set title adcdOK127.0.0.1:6379> get title"adcd"127.0.0.1:6379> set title 2OK127.0.0.1:6379> get title"2"127.0.0.1:6379>复制代码

让redis进程在后台运行

./redis-server& redis.conf

另一种方式就是修改后台文件:

[root@server1 bin]# vim redis.conf

daemonize no变成 yes
然后:

[root@server1 bin]# ./redis-server redis.conf

高版本会遇到的奇怪问题:

基本命令的使用:

127.0.0.1:6379> set title 1234OK127.0.0.1:6379> set name jerryOK127.0.0.1:6379> keys *1) "title"2) "name"127.0.0.1:6379>复制代码

keys * 命令查找当前库下面所有的key值。keys 后面可以跟上一个正则表达式。

当key不存在时:

127.0.0.1:6379> keys age(empty list or set)复制代码

随机的获取一个key

randomkey

127.0.0.1:6379> randomkey"name"127.0.0.1:6379> randomkey"name"127.0.0.1:6379> randomkey"title"127.0.0.1:6379> randomkey"title"127.0.0.1:6379> randomkey"name"127.0.0.1:6379> randomkey"title"127.0.0.1:6379> randomkey"name"127.0.0.1:6379> randomkey"sex"复制代码

判断key是否存在

exists key +key名字

1表示存在,0表示不存在

127.0.0.1:6379> exists key name(integer) 1127.0.0.1:6379> exists key birthday(integer) 0127.0.0.1:6379>复制代码

删除key

del key1 key2 ...

127.0.0.1:6379> del  title(integer) 1127.0.0.1:6379> keys *1) "sex"2) "name"127.0.0.1:6379> 127.0.0.1:6379> del sex name(integer) 2127.0.0.1:6379> keys *(empty list or set)127.0.0.1:6379>复制代码

改变key的名字

127.0.0.1:6379> set name jerryOK127.0.0.1:6379> set age 24OK127.0.0.1:6379> set sex 1OK127.0.0.1:6379> keys *1) "sex"2) "age"3) "name"127.0.0.1:6379> rename name nicknameOK127.0.0.1:6379> keys *1) "nickname"2) "sex"3) "age"127.0.0.1:6379>复制代码

如果试图修改一个不存在的key,将会报出错误:

127.0.0.1:6379> rename name nickname(error) ERR no such key复制代码

但是有一种情况,如果说改名后的新的key名已经存在,那么原来的key该怎么办呢?

127.0.0.1:6379> rename sex  ageOK127.0.0.1:6379> get age"1"127.0.0.1:6379>复制代码

请注意,age原来是24.现在是1.

使用renamenx安全的替换key:

127.0.0.1:6379> set name  jerryOK127.0.0.1:6379> set age 24OK127.0.0.1:6379> set sex 1OK复制代码

127.0.0.1:6379> renamenx sex age

如果修改成功,将返回1,修改失败(不作任何操作)将返回0

redis的数据库

cat redis.conf

可以查看到 redis在初始化的时候为我们初始化了16个数据库。redis默认使用0号数据库。并告知使用select 命令来选择数据库:

# Set the number of databases. The default database is DB 0, you can select# a different one on a per-connection basis using SELECT 
where# dbid is a number between 0 and 'databases'-1databases 16复制代码

假设超过了数据库的索引,就会报出非法的DB索引:

127.0.0.1:6379> select 23(error) ERR invalid DB index127.0.0.1:6379>复制代码

move:将key移动到别的数据库

127.0.0.1:6379> keys *1) "nickname"2) "sex"3) "age"127.0.0.1:6379> move sex 1(integer) 1127.0.0.1:6379> keys *1) "nickname"2) "age"127.0.0.1:6379>复制代码

此时选择1号数据库:

127.0.0.1:6379> select 1OK127.0.0.1:6379[1]> keys *1) "sex"127.0.0.1:6379[1]>复制代码

expire设置有效期

memcache有有效期,即使设置为永不失效,也只能保存30天。redis本身是当做存储的,所以没有有效期,即永远不失效。

1.ttl查询有效期,默认返回秒单位计时

127.0.0.1:6379> keys *1) "nickname"2) "age"127.0.0.1:6379> ttl age(integer) -1127.0.0.1:6379> 返回-1表示永久有效复制代码

如果查询一个不在的key的生命周期,将会返回-2(2.8以后)

127.0.0.1:6379> ttl gender(integer) -2复制代码
  1. expire设置有效期,是用秒作为单位的。
127.0.0.1:6379> expire age 10(integer) 1127.0.0.1:6379> get age"24"127.0.0.1:6379> get age"24"127.0.0.1:6379> get age(nil)127.0.0.1:6379>复制代码

3.pttl和pexpire:使用毫秒作为声明周期

127.0.0.1:6379> pttl age(integer) -1127.0.0.1:6379> pexpire age 100000(integer) 1127.0.0.1:6379> pttl age(integer) 97177127.0.0.1:6379> pttl age(integer) 94561127.0.0.1:6379> pttl age(integer) 93000127.0.0.1:6379> pttl age(integer) 91937127.0.0.1:6379>复制代码

persist:让 key重新永久有效

127.0.0.1:6379> set age 24OK127.0.0.1:6379> expire age 20(integer) 1127.0.0.1:6379> ttl age(integer) 14127.0.0.1:6379>  persist age(integer) 1127.0.0.1:6379> ttl age(integer) -1127.0.0.1:6379>复制代码

set命令:重复设置key怎么办

对相同的key多次设置值,会直接覆盖:

127.0.0.1:6379> flushdbOK127.0.0.1:6379> keys *(empty list or set)127.0.0.1:6379>  set  name  jerryOK127.0.0.1:6379> set name   herryOK127.0.0.1:6379> get name"herry"127.0.0.1:6379>复制代码

使用 set keyname value nx 来保证如果已经有这个key就不做任何操作,防止key被覆盖:

127.0.0.1:6379> set site www.baodu.comOK127.0.0.1:6379> set site www.taobao.com  nx(nil)127.0.0.1:6379> get site"www.baodu.com"127.0.0.1:6379>复制代码

此外还有一个xx选项。

append :追加

setrange 与 getrange

getset:先得到旧的值,再设置新值

127.0.0.1:6379> set  status  sleepOK127.0.0.1:6379> getset status work"sleep"127.0.0.1:6379> get status"work"127.0.0.1:6379>复制代码

加一与减一:

incr 与 decr

127.0.0.1:6379> set  age 20OK127.0.0.1:6379> incr age(integer) 21127.0.0.1:6379> get age"21"127.0.0.1:6379> decr age(integer) 20127.0.0.1:6379>复制代码

如果是一个字符串呢?

127.0.0.1:6379> incr  status(error) ERR value is not an integer or out of range127.0.0.1:6379>复制代码

redis:秒杀系统的设计与实践

一次增加或减少指定的数字

127.0.0.1:6379> incrby  age 5(integer) 25127.0.0.1:6379>复制代码

###一次增加或减少指定的浮点型数字

127.0.0.1:6379> incrbyfloat  age 0.6"25.6"复制代码

位操作

位操作就是在 0和1 位上来操作。

127.0.0.1:6379> set char AOK127.0.0.1:6379> setbit char 2 1(integer) 0127.0.0.1:6379> get char"a"127.0.0.1:6379>复制代码

上图演示了对char这个key 进行位操作,

引用:

UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度,当字符在ASCII码的范围时,就用一个字节表示,保留了ASCII字符一个字节的编码做为它的一部分,注意的是unicode一个中文字符占2个字节,而UTF-8一个中文字符占3个字节

redis存储是UTF-8.之所以能够位操作,就是因为与acii码保持了统一。不然就不是offset2了。

使用redis的位操作可以用来统计在线人数。。等等。。。

redis的位操作offset过大,就会填充0。与本身存储的大小无关。

127.0.0.1:6379> set name "你好"OK127.0.0.1:6379> get name"\xe4\xbd\xa0\xe5\xa5\xbd"127.0.0.1:6379> setbit name 5 0(integer) 1127.0.0.1:6379> get name"\xe0\xbd\xa0\xe5\xa5\xbd"127.0.0.1:6379>复制代码

你好,总共是两个汉字,6个字节。

redis所有的存储都是string,set int 1 实际上是 存储了1这个字符串(ascii编码)

实际上,可以直接设置位,比如:

127.0.0.1:6379> setbit lower 2 1
lower并不存在,设置完毕以后就是 00100000

127.0.0.1:6379> setbit lower 2 1(integer) 0127.0.0.1:6379> get lower" "127.0.0.1:6379> setbit lower 3 1(integer) 0127.0.0.1:6379> get lower"0"127.0.0.1:6379>复制代码

打印出0,因为0的ascii码就是00110000。

bitop:位操作

假设有这样一个需求,要将大写的字符始终转换成小写的字符,可以使用bittop来操作。

由于小写字母的整数值始终比大写字母多32,可以使用OR操作来直接位运算:

127.0.0.1:6379> flushdbOK127.0.0.1:6379> setbit lower 2 1(integer) 0127.0.0.1:6379> set char QOK127.0.0.1:6379> bitop or char  char lower(integer) 1127.0.0.1:6379> get char"q"127.0.0.1:6379>复制代码

bitop中的第一个参数or可以是 andornot, xor

第二个参数是结果存放于哪个key
第三,四个参数表示 操作的两个key

#链表

lpush 链表名(key) 值
像这个链表左端推入,
rpush 链表名(key) 值
从这个链表左端插入。

127.0.0.1:6379> lpush list a //从list这个链表左端插入a,如下以此类推(integer) 1127.0.0.1:6379> rpush list b(integer) 2127.0.0.1:6379> rpush list c(integer) 3127.0.0.1:6379> lpush list 0(integer) 4127.0.0.1:6379> lrange 0 4(error) ERR wrong number of arguments for 'lrange' command127.0.0.1:6379> lrange list 0 41) "0"2) "a"3) "b"4) "c"127.0.0.1:6379>复制代码

lrange list 0 4 查看链表内容。从左边则是0开始,右边是-1开始,因为事先真不知道链表个数

所以要查看所有的内容,可以:
lrange list 0 -1

lpush与rpush也支持一次性插入多个值:

127.0.0.1:6379> lpush anwser a b c d e f g(integer) 7127.0.0.1:6379> lrange  anwser 0 -11) "g"2) "f"3) "e"4) "d"5) "c"6) "b"7) "a"127.0.0.1:6379>复制代码

从左边插入自然是倒着的。

lpop与rpop:从链表左端或者链表右端弹出值

删除指定的值

Redis Lrem 根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。

COUNT 的值可以是以下几种:

count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。count = 0 : 移除表中所有与 VALUE 相等的值。复制代码
127.0.0.1:6379> rpush anwser a b b b c d e f g(integer) 9127.0.0.1:6379> rrme anwser 2 b(error) ERR unknown command 'rrme'127.0.0.1:6379> rrem anwser 2 b(error) ERR unknown command 'rrem'127.0.0.1:6379> lrem anwser 2 b(integer) 2127.0.0.1:6379> lrange  anwser 0 -11) "a"2) "b"3) "c"4) "d"5) "e"6) "f"7) "g"127.0.0.1:6379>复制代码

查看集群目前状况

redis-cli -c -p 16001

打印集群的信息

cluster info

列出集群当前已知的所有节点(node),以及这些节点的相关信息。

cluster nodes

转载地址:http://jhpwx.baihongyu.com/

你可能感兴趣的文章
有利于seo优化的网站地图不能取巧
查看>>
快照产品体验优化
查看>>
ASCII
查看>>
ibatis SqlMap not found
查看>>
Android SD卡创建文件和文件夹失败
查看>>
Ubuntu 14.04 vsftp refusing to run with writable root inside chroot问题解决方法
查看>>
Intellij IDEA远程调试tomcat
查看>>
hadoop的学习论坛
查看>>
替代Windows Cmd的利器PowerCmd
查看>>
Struts2 学习小结
查看>>
Linux IPMI 安装配置实用
查看>>
烂泥:wordpress迁移到docker
查看>>
.扒渣机的性能及优势 
查看>>
Linux下磁盘保留空间的调整,解决df看到的空间和实际磁盘大小不一致的问题
查看>>
RSA 生成公钥、私钥对
查看>>
C# ASP.NET 权限设计 完全支持多数据库多语言包的通用权限管理系统组件源码
查看>>
测试工具综合
查看>>
asp.net中调用COM组件发布IIS时常见错误 80070005解决方案
查看>>
分享一段ios数据库代码,包括对表的创建、升级、增删查改
查看>>
如何书写高质量的jQuery代码
查看>>