- 浏览: 7944063 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (2425)
- 软件工程 (75)
- JAVA相关 (662)
- ajax/web相关 (351)
- 数据库相关/oracle (218)
- PHP (147)
- UNIX/LINUX/FREEBSD/solaris (118)
- 音乐探讨 (1)
- 闲话 (11)
- 网络安全等 (21)
- .NET (153)
- ROR和GOG (10)
- [网站分类]4.其他技术区 (181)
- 算法等 (7)
- [随笔分类]SOA (8)
- 收藏区 (71)
- 金融证券 (4)
- [网站分类]5.企业信息化 (3)
- c&c++学习 (1)
- 读书区 (11)
- 其它 (10)
- 收藏夹 (1)
- 设计模式 (1)
- FLEX (14)
- Android (98)
- 软件工程心理学系列 (4)
- HTML5 (6)
- C/C++ (0)
- 数据结构 (0)
- 书评 (3)
- python (17)
- NOSQL (10)
- MYSQL (85)
- java之各类测试 (18)
- nodejs (1)
- JAVA (1)
- neo4j (3)
- VUE (4)
- docker相关 (1)
最新评论
-
xiaobadi:
jacky~~~~~~~~~
推荐两个不错的mybatis GUI生成工具 -
masuweng:
(转)JAVA获得机器码的实现 -
albert0707:
有些扩展名为null
java 7中可以判断文件的contenttype了 -
albert0707:
非常感谢!!!!!!!!!
java 7中可以判断文件的contenttype了 -
zhangle:
https://zhuban.me竹板共享 - 高效便捷的文档 ...
一个不错的网络白板工具
https://gold.xitu.io/post/5880590d1b69e60058c72803
解压后的安装
[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]# 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
出现:
_._
_.-``__ ''-._
_.-`` `. `_. ''-._ 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
这只是前台启动,关闭终端自动停止。
新建一个窗口,进入终端命令:
[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进程在后台运行
./redis-server& redis.conf
另一种方式就是修改后台文件:
[root@server1 bin]# vim redis.conf
将daemonize no变成 yes
然后:
[root@server1 bin]# ./redis-server redis.conf
高版本会遇到的奇怪问题:
http://blog.csdn.net/qq_25797077/article/details/51986455
基本命令的使用:
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)
随机的获取一个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) 1
127.0.0.1:6379> exists key birthday
(integer) 0
127.0.0.1:6379>
删除key
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>
改变key的名字
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.
使用renamenx安全的替换key:
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
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 <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>
move:将key移动到别的数据库
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]>
expire设置有效期
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>
persist:让 key重新永久有效
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>
set命令:重复设置key怎么办
对相同的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选项。
append :追加
setrange 与 getrange
getset:先得到旧的值,再设置新值
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/question/20001177
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。
bitop:位操作
假设有这样一个需求,要将大写的字符始终转换成小写的字符,可以使用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>
从左边插入自然是倒着的。
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) 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
列出集群当前已知的所有节点(node),以及这些节点的相关信息。
cluster nodes
解压后的安装
[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]# 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
出现:
_._
_.-``__ ''-._
_.-`` `. `_. ''-._ 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
这只是前台启动,关闭终端自动停止。
新建一个窗口,进入终端命令:
[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进程在后台运行
./redis-server& redis.conf
另一种方式就是修改后台文件:
[root@server1 bin]# vim redis.conf
将daemonize no变成 yes
然后:
[root@server1 bin]# ./redis-server redis.conf
高版本会遇到的奇怪问题:
http://blog.csdn.net/qq_25797077/article/details/51986455
基本命令的使用:
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)
随机的获取一个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) 1
127.0.0.1:6379> exists key birthday
(integer) 0
127.0.0.1:6379>
删除key
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>
改变key的名字
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.
使用renamenx安全的替换key:
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
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 <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>
move:将key移动到别的数据库
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]>
expire设置有效期
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>
persist:让 key重新永久有效
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>
set命令:重复设置key怎么办
对相同的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选项。
append :追加
setrange 与 getrange
getset:先得到旧的值,再设置新值
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/question/20001177
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。
bitop:位操作
假设有这样一个需求,要将大写的字符始终转换成小写的字符,可以使用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>
从左边插入自然是倒着的。
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) 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
列出集群当前已知的所有节点(node),以及这些节点的相关信息。
cluster nodes
发表评论
-
复习:强迫线程顺序执行方式
2019-01-03 23:42 1579方法1: 三个线程,t1,t2,t3,如果一定要按顺序执行, ... -
(转)不错的前后端处理异常的方法
2019-01-02 23:16 2019前言 在 Web 开发中, 我们经常会需要处理各种异常, 这是 ... -
info q的极客时间大咖说等资料下载
2018-08-15 08:40 3472info q的极客时间大咖说等资料下载,还有不少思维导图 链 ... -
CXF 客户端超时时间设置(非Spring配置方式)
2018-07-03 22:38 2236import org.apache.cxf.endpoint. ... -
(转)synchronized关键字画像:正确打开方式
2018-06-14 09:25 490https://mp.weixin.qq.com/s/b3Sx ... -
CountDownLatch的例子
2018-06-13 14:10 691public class StatsDemo { ... -
两道面试题,带你解析Java类加载机制
2018-06-12 16:29 611https://mp.weixin.qq.com/s/YTa0 ... -
Spring中获取request的几种方法,及其线程安全性分析
2018-06-11 09:03 671https://mp.weixin.qq.com/s/KeFJ ... -
内部类小结
2018-06-06 10:25 438https://mp.weixin.qq.com/s/hErv ... -
JVM虚拟机小结1
2018-06-04 20:43 5441 jps -l //列出详细的类名和进程ID 2)jps ... -
windows下自带命令行工具查看CPU资源情况等
2018-06-04 12:53 3101微软提供了不少命令行 ... -
(收藏)深入分析Java的序列化与反序列化
2018-05-30 15:21 617https://mp.weixin.qq.com/s/T2Bn ... -
apache common包中的序列化工具
2018-05-30 09:10 1844什么是序列化 我们的 ... -
JAVA8 JVM的变化: 元空间(Metaspace)
2018-05-24 22:30 967本文将会分享至今为至我收集的关于永久代(Permanent G ... -
(转)服务器性能指标(一)——负载(Load)分析及问题排查
2018-05-21 21:03 1363原创: Hollis Hollis 负载 ... -
(转)对象复用
2018-05-20 15:27 863public class Student { priv ... -
mapreduce中入门中要注意的几点
2018-05-06 08:59 674在 mapreduce中,比如有如下的词: I love b ... -
HDFS的基本操作
2018-05-02 21:47 941-mkdir 在HDFS创建目录 ... -
一个不错的开源工具类,专门用来解析日志头部的,好用
2018-05-02 20:00 772一个不错的开源工具类,专门用来解析日志头部的,好用。 http ... -
介绍个不错的RESTFUL MOCK的工具wiremock
2018-04-27 21:02 1907介绍个不错的RESTFUL MOCK的工具wiremock,地 ...
相关推荐
1. **Redis快速入门**:这部分通常会介绍如何安装Redis,包括在各种操作系统(如Linux、Windows、macOS)上的安装步骤。还会讲解Redis服务器的启动与停止,以及配置文件的基本设置。此外,客户端工具的使用,如`...
redis快速入门详解,包括主从备份、详细配置说明~
redis的快速入门与详解.让你快速了解和掌握redis的使用
"Redis快速入门ppt" Redis快速入门 ppt 介绍了 Redis 的基础知识,包括 NoSQL 的概念、Redis 的安装、Redis 的常见命令、Redis 的 Java 客户端等。 认识 NoSQL NoSQL 是一种非关系型数据库,它不同于传统的关系型...
redis快速入门详解PPT 讲解全面很不错的-------------------------------------------------------------------------------------------------------------------------------------------------
Redis 快速入门详解 Redis 是一款开源的、高性能的键值存储系统(key-value store),常被称作是一款数据结构服务器(data structure server)。Redis 的键值可以包括字符串(strings)类型,同时它还包括哈希...
redis快速入门 (阳哥课堂笔记),内容包括redis的安装、Redis的数据类型、Redis的持久化、解析配置文件、Redis的事务、Redis集群
【NOSQL数据库-Redis快速入门】 NOSQL(Not Only SQL)数据库是近年来新兴的一类数据库系统,它与传统的关系型数据库相比有着显著的区别。NOSQL数据库不支持SQL语法,其数据存储结构通常不遵循关系表模型,而是采用...
以下是对Redis快速入门的详细讲解: 1. **Redis简介** Redis是一个开源(BSD许可),内存中的数据结构存储系统,它可以用作数据库、缓存和消息代理。它的特点是数据持久化、支持多种数据结构(如字符串、哈希、...
本章将为你提供一个Redis快速入门的指南,让你掌握基本的使用方法和概念。 一、Redis概述 Redis(Remote Dictionary Server)是一个开源的、基于内存的数据结构存储系统,支持数据持久化,可作为数据库、缓存和消息...
redis讲解入门PPT介绍
在本文中,我们将深入探讨如何使用SpringBoot集成Redis进行快速入门。这个Demo旨在展示如何配置SpringBoot项目,以便能够利用Redis进行数据的读、写和删除操作。首先,我们需要了解项目的基本环境设置。 1. **环境...
本手册专为新手小白设计,旨在帮助初学者快速掌握Redis的基本概念、操作及应用。 1. **Redis简介** Redis是Remote Dictionary Server的缩写,由Salvatore Sanfilippo开发,它是一款开源、基于内存且支持持久化的...
本指南将帮助初学者理解 Redis 的基本概念、安装与配置、数据类型以及常用命令,从而快速入门 Redis。 1. **Redis 简介** - Redis 源自意大利程序员 Salvatore Sanfilippo,最初是为了提高网站性能而设计的。 - ...
Redis快速入门PPT,非常详细,非常基础。学会基础就掌握了一大半了,做的非常不错的PPT,非常值得下载。
4. **实时数据分析**:通过Redis处理大量实时数据流,实现快速统计分析。 #### 七、Redis最佳实践 1. **优化数据模型**:合理设计数据结构,避免频繁修改数据。 2. **合理设置过期时间**:对于不需要长期存储的...
本自学视频课程旨在帮助初学者从零基础快速掌握Redis的基本概念、常用操作以及如何实现高可用性。通过12个章节的深入讲解,将使您对Redis有全面而深入的理解。 第一章:Redis简介与安装 本章将介绍Redis的基本概念...
Redis 演示Redis演示Redis快速入门及应用第7章的演示下载及更多资料RedisDemo下载地址https://github.com/das2017/RedisDemoRedisDesktopManage下载地址https://redisdesktop.com/Redis官网...新产品上市京东链接...