[root@server1 redis-3.0.5]# make
node
指定安装目录:正则表达式
[root@server1 redis-3.0.5]# make PREFIX=/usr/local/redis install
进入/usr/local/redis里面:redis
[root@server1 redis]# ls bin [root@server1 redis]# cd bin [root@server1 bin]# ls redis-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
出现:vim
_._ _.-``__ ''-._ _.-`` `. `_. ''-._ 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.5 23880: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
这只是前台启动,关闭终端自动中止。安全
新建一个窗口,进入终端命令:app
[root@server1 ~]# cd /usr/local/redis [root@server1 redis]# ls bin [root@server1 redis]# cd bin [root@server1 bin]# ls redis-benchmark redis-check-dump redis.conf redis-server redis-check-aof redis-cli redis-sentinel [root@server1 bin]# ./redis-cli 127.0.0.1:6379> 127.0.0.1:6379> set title adcd OK 127.0.0.1:6379> get title "adcd" 127.0.0.1:6379> set title 2 OK 127.0.0.1:6379> get title "2" 127.0.0.1:6379>
./redis-server& redis.conf
dom
另外一种方式就是修改后台文件:this
[root@server1 bin]# vim redis.conf
将daemonize no
变成 yes
而后:编码
[root@server1 bin]# ./redis-server redis.conf
http://blog.csdn.net/qq_25797...
127.0.0.1:6379> set title 1234 OK 127.0.0.1:6379> set name jerry OK 127.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)
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"
exists key +key名字
1表示存在,0表示不存在
127.0.0.1:6379> exists key name (integer) 1 127.0.0.1:6379> exists key birthday (integer) 0 127.0.0.1:6379>
del key1 key2 ...
127.0.0.1:6379> del title (integer) 1 127.0.0.1:6379> keys * 1) "sex" 2) "name" 127.0.0.1:6379> 127.0.0.1:6379> del sex name (integer) 2 127.0.0.1:6379> keys * (empty list or set) 127.0.0.1:6379>
127.0.0.1:6379> set name jerry OK 127.0.0.1:6379> set age 24 OK 127.0.0.1:6379> set sex 1 OK 127.0.0.1:6379> keys * 1) "sex" 2) "age" 3) "name" 127.0.0.1:6379> rename name nickname OK 127.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 age OK 127.0.0.1:6379> get age "1" 127.0.0.1:6379>
请注意,age原来是24.如今是1.
127.0.0.1:6379> set name jerry OK 127.0.0.1:6379> set age 24 OK 127.0.0.1:6379> set sex 1 OK
127.0.0.1:6379> renamenx sex age
若是修改为功,将返回1,修改失败(不做任何操做)将返回0
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 <dbid> where # dbid is a number between 0 and 'databases'-1 databases 16
假设超过了数据库的索引,就会报出非法的DB索引:
127.0.0.1:6379> select 23 (error) ERR invalid DB index 127.0.0.1:6379>
127.0.0.1:6379> keys * 1) "nickname" 2) "sex" 3) "age" 127.0.0.1:6379> move sex 1 (integer) 1 127.0.0.1:6379> keys * 1) "nickname" 2) "age" 127.0.0.1:6379>
此时选择1号数据库:
127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]> keys * 1) "sex" 127.0.0.1:6379[1]>
memcache有有效期,即便设置为永不失效,也只能保存30天。redis自己是当作存储的,因此没有有效期,即永远不失效。
1.ttl查询有效期,默认返回秒单位计时
127.0.0.1:6379> keys * 1) "nickname" 2) "age" 127.0.0.1:6379> ttl age (integer) -1 127.0.0.1:6379> 返回-1表示永久有效
若是查询一个不在的key的生命周期,将会返回-2(2.8之后)
127.0.0.1:6379> ttl gender (integer) -2
expire设置有效期,是用秒做为单位的。
127.0.0.1:6379> expire age 10 (integer) 1 127.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) -1 127.0.0.1:6379> pexpire age 100000 (integer) 1 127.0.0.1:6379> pttl age (integer) 97177 127.0.0.1:6379> pttl age (integer) 94561 127.0.0.1:6379> pttl age (integer) 93000 127.0.0.1:6379> pttl age (integer) 91937 127.0.0.1:6379>
127.0.0.1:6379> set age 24 OK 127.0.0.1:6379> expire age 20 (integer) 1 127.0.0.1:6379> ttl age (integer) 14 127.0.0.1:6379> persist age (integer) 1 127.0.0.1:6379> ttl age (integer) -1 127.0.0.1:6379>
对相同的key屡次设置值,会直接覆盖:
127.0.0.1:6379> flushdb OK 127.0.0.1:6379> keys * (empty list or set) 127.0.0.1:6379> set name jerry OK 127.0.0.1:6379> set name herry OK 127.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.com OK 127.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选项。
127.0.0.1:6379> set status sleep OK 127.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 20 OK 127.0.0.1:6379> incr age (integer) 21 127.0.0.1:6379> get age "21" 127.0.0.1:6379> decr age (integer) 20 127.0.0.1:6379>
若是是一个字符串呢?
127.0.0.1:6379> incr status (error) ERR value is not an integer or out of range 127.0.0.1:6379>
redis:秒杀系统的设计与实践
127.0.0.1:6379> incrby age 5 (integer) 25 127.0.0.1:6379>
127.0.0.1:6379> incrbyfloat age 0.6 "25.6"
位操做就是在 0和1 位上来操做。
127.0.0.1:6379> set char A OK 127.0.0.1:6379> setbit char 2 1 (integer) 0 127.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的位操做能够用来统计在线人数。。等等。。。
https://www.zhihu.com/questio...
redis的位操做offset过大,就会填充0。与自己存储的大小无关。
127.0.0.1:6379> set name "你好" OK 127.0.0.1:6379> get name "\xe4\xbd\xa0\xe5\xa5\xbd" 127.0.0.1:6379> setbit name 5 0 (integer) 1 127.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) 0 127.0.0.1:6379> get lower " " 127.0.0.1:6379> setbit lower 3 1 (integer) 0 127.0.0.1:6379> get lower "0" 127.0.0.1:6379>
打印出0,由于0的ascii码就是00110000。
假设有这样一个需求,要将大写的字符始终转换成小写的字符,可使用bittop来操做。
因为小写字母的整数值始终比大写字母多32,可使用OR操做来直接位运算:
127.0.0.1:6379> flushdb OK 127.0.0.1:6379> setbit lower 2 1 (integer) 0 127.0.0.1:6379> set char Q OK 127.0.0.1:6379> bitop or char char lower (integer) 1 127.0.0.1:6379> get char "q" 127.0.0.1:6379>
bitop中的第一个参数or能够是 and
,or
,not
, xor
第二个参数是结果存放于哪一个key
第三,四个参数表示 操做的两个key
lpush 链表名(key) 值
像这个链表左端推入,
rpush 链表名(key) 值
从这个链表左端插入。
127.0.0.1:6379> lpush list a //从list这个链表左端插入a,以下以此类推 (integer) 1 127.0.0.1:6379> rpush list b (integer) 2 127.0.0.1:6379> rpush list c (integer) 3 127.0.0.1:6379> lpush list 0 (integer) 4 127.0.0.1:6379> lrange 0 4 (error) ERR wrong number of arguments for 'lrange' command 127.0.0.1:6379> lrange list 0 4 1) "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) 7 127.0.0.1:6379> lrange anwser 0 -1 1) "g" 2) "f" 3) "e" 4) "d" 5) "c" 6) "b" 7) "a" 127.0.0.1:6379>
从左边插入天然是倒着的。
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) 9 127.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) 2 127.0.0.1:6379> lrange anwser 0 -1 1) "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
cluster nodes