当前位置:操作系统 > Unix/Linux >>

Redis数据类型学习

Redis数据类型学习
 
Redis是一款开源,高性能键-值存储(key-value store).它的键值可以包括字符串(strings)类型,同时它还包括哈希(hashes),列表(lists),集合(sets)等数据类型.对于这些数据类型,可以执行原子操作.例如:对字符串进行附加操作(append);递增哈希中的值;向列表中增加元素;计算集合的交集,并集与差集等.
 
经常有人拿memcached和redis做比较.下面简单看下他们之间有哪些差别:
 
1.网络IO模型
 
memcached是多线程,非阻塞IO复用的网络模型.多线程模型可以发回多核作用,但有时也带来性能损耗.
 
redis使用单线程的IO复用模型.自己封装了一个简单的AeEvent事件处理框架,主要实现了epoll,kqueue和select,对于单纯只有IO操作来说,单线程可以将速度优势发挥到最大,但是一些操作,如排序,聚合等,单线程模型实际会严重影响整体吞吐量.
 
2.内存管理
 
memcached使用预分配的内存池的方式.能省去申请释放内存的开销,减小内存碎片产生,但这种方式也会带来一定程度上的空间浪费.数据也可能被剔除.
 
redis使用现场申请内存的方式来存储数据.优化内存分配,非临时数据永远不会被剔除,即便物理内存不够.这点redis更适合作为存储而不是cache
 
3.存储方式
 
memcached基本只支持简单的key-value存储,不支持枚举,不支持持久化和复制等功能.
 
redis除key/value之外,还支持list,set,sorted,hash等数据结构.同时还支持持久化和复制等功能.
 
如果希望数据不被剔除,或者需要key-value之外更多数据类型支持时,使用redis更适合.
 
下面安装Redis.
 
1.下载redis redis-2.4.14.tar.gz  http://code.google.com/p/redis/downloads/list
 
01
root@10.1.1.45:~# ls -l redis-2.4.14.tar.gz
02
-rw-r--r-- 1 root root 627494 2013-05-08 16:16 redis-2.4.14.tar.gz
03
root@10.1.1.45:~# tar xf redis-2.4.14.tar.gz
04
root@10.1.1.45:~# cd redis-2.4.14/
05
root@10.1.1.45:redis-2.4.14# ll
06
total 84
07
-rw-rw-r-- 1 root root 12105 2012-05-23 17:32 00-RELEASENOTES
08
-rw-rw-r-- 1 root root    55 2012-05-23 17:32 BUGS
09
-rw-rw-r-- 1 root root   671 2012-05-23 17:32 CONTRIBUTING
10
-rw-rw-r-- 1 root root  1487 2012-05-23 17:32 COPYING
11
drwxrwxr-x 5 root root  4096 2012-05-23 17:32 deps
12
-rw-r--r-- 1 root root    25 2013-05-08 16:15 dump.rdb
13
-rw-rw-r-- 1 root root    30 2012-05-23 17:32 INSTALL
14
-rw-rw-r-- 1 root root   397 2012-05-23 17:32 Makefile
15
-rw-rw-r-- 1 root root  2813 2012-05-23 17:32 README
16
-rw-rw-r-- 1 root root 21094 2012-05-23 17:32 redis.conf
17
-rwxrwxr-x 1 root root   162 2012-05-23 17:32 runtest
18
drwxrwxr-x 2 root root  4096 2013-05-08 16:10 src
19
drwxrwxr-x 8 root root  4096 2012-05-23 17:32 tests
20
drwxrwxr-x 2 root root  4096 2012-05-23 17:32 utils
21
root@10.1.1.45:redis-2.4.14# make
22
root@10.1.1.45:redis-2.4.14# mkdir /etc/redis/
23
root@10.1.1.45:redis-2.4.14# cp redis.conf /etc/redis/redis.conf #拷贝配置文件
24
root@10.1.1.45:redis-2.4.14# echo "1" > /proc/sys/vm/overcommit_memory
/proc/sys/vm/overcommit_memory 
可选值:0、1、2。 
0,表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。 
1,表示内核允许分配所有的物理内存,而不管当前的内存状态如何。 
2,表示内核允许分配超过所有物理内存和交换空间总和的内存
这里选择1,如果不选后面make install 会提示warning.
 
1
root@10.1.1.45:redis-2.4.14# make install
2.启动redis服务
1
root@10.1.1.45:redis-2.4.14# redis-server /etc/redis/redis.conf
2
[11349] 08 May 20:42:05 * Server started, Redis version 2.4.14
3
[11349] 08 May 20:42:05 * DB loaded from disk: 0 seconds
4
[11349] 08 May 20:42:05 * The server is now ready to accept connections on port 6379
5
[11349] 08 May 20:42:05 - DB 0: 1 keys (0 volatile) in 4 slots HT.
6
[11349] 08 May 20:42:05 - 0 clients connected (0 slaves), 717592 bytes in use
7
[11349] 08 May 20:42:11 - DB 0: 1 keys (0 volatile) in 4 slots HT.
8
[11349] 08 May 20:42:11 - 0 clients connected (0 slaves), 717592 bytes in use
这里还需要设置redis进程为后台守护进程.
1
root@10.1.1.45:redis-2.4.14# vim /etc/redis/redis.conf
2
daemonize yes
3
root@10.1.1.45:redis-2.4.14# redis-server /etc/redis/redis.conf
4
root@10.1.1.45:redis-2.4.14# ps -ef | grep redis
5
root     10987  6834  0 17:07 pts/1    00:00:00 redis-cli
6
root     11394     1  0 20:44 ?        00:00:00 redis-server /etc/redis/redis.conf
3.测试redis
01
root@10.1.1.45:redis-2.4.14# redis-cli #redis命令操作工具
02
redis 127.0.0.1:6379> set name davehe
03
OK
04
redis 127.0.0.1:6379> get name
05
"davehe"
06
redis 127.0.0.1:6379> hset 192.168.1 test test@123 #设置1网段test用户密码
07
(integer) 1
08
redis 127.0.0.1:6379> hget 192.168.1 test #获取test值
09
"test@123"
10
redis 127.0.0.1:6379> hset 192.168.1 root root@123 #设置1网段root用户密码
11
(integer) 1
12
redis 127.0.0.1:6379> hget 192.168.1 root #获取root值
13
"root@123"
14
redis 127.0.0.1:6379> hkeys 192.168.1  #返回hash所有的field
15
1) "test"
16
2) "root"
17
redis 127.0.0.1:6379> hvals 192.168.1  #返回hash所有的value
18
1) "test@123"
19
2) "root@123"
20
redis 127.0.0.1:6379> hgetall 192.168.1 #返回hash所有filed和value
21
1) "test"
22
2) "test@123"
23
3) "root"
24
4) "root@123"
25
redis 127.0.0.1:6379> type name      #查看类型 不同类型需要不同命令去获取值.
26
string
27
redis 127.0.0.1:6379> type 192.168.1
28
hash
29
redis 127.0.0.1:6379> keys *         #查看所有key
30
1) "name"
31
2) "192.168.1."
4.关闭redis服务
 
1
root@10.1.1.45:redis-2.4.14# redis-cli shutdown
 
附录相关redis命令:
 
连接操作相关的命令
 
quit:关闭连接(connection)
auth:简单密码认证
 
持久化
 
save:将数据同步保存到磁盘
bgsave:将数据异步保存到磁盘
lastsave:返回上次成功将数据保存到磁盘的Unix时戳
shundown:将数据同步保存到磁盘,然
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,