安装步骤
下载地址:http://redis.io/download,下载最新文档版本。
本教程使用版本为 3.0.4,下载并安装:
wget install -y http://download.redis.io/releases/redis-3.0.4.tar.gz
tar -zxvf redis-3.0.4.tar.gz
cd redis-3.0.4
make
make PREFIX=/opt/install/redis304(指定目录) install
如make报错,可能是没有安装gcc,因为redis是用C语言编写的,安装下gcc就可以了
yum install -y gcc g++ gcc-c++ make
再次执行make,若make出现错误为:致命错误,执行以下命令
make MALLOC=libc
再继续make
将redis.conf文件复制到指定目录
[root@hadoop82 redis-3.0.4] cp ./redis.conf /opt/install/redis304/
需要后台启动的,修改redis配置文件
cd redis304/
vi redis.conf
################################ GENERAL #####################################
# By default Redis does not run as a daemon. Use 'yes' if you need it.
# Note that Redis will write a pid file in /var/run/redis.pid when daemonized.
daemonize yes (此处改为yes,默认是no)
启动redis服务
[root@hadoop82 redis304] ./bin/redis-server redis.conf
启动redis客户端
[root@hadoop82 redis304]# ./bin/redis-cli
127.0.0.1:6379> set kb11 verygood
OK
127.0.0.1:6379> get kb11
"verygood"
127.0.0.1:6379>
redis启动成功!!!
redis数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
String(字符串)
string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
string类型是Redis最基本的数据类型,一个键最大能存储512MB。
实例
redis 127.0.0.1:6379> SET name "shouce.ren"
2.OK
3.redis 127.0.0.1:6379> GET name
4."shouce.ren"
在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 name,对应的值为shouce.ren。
注意:一个键最大能存储512MB。
Hash(哈希)
Redis hash 是一个键值对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
实例
redis 127.0.0.1:6379> HMSET user:1 username shouce.ren password shouce.ren points 200
2.OK
3.redis 127.0.0.1:6379> HGETALL user:1
4.1) "username"
5.2) "shouce.ren"
6.3) "password"
7.4) "shouce.ren"
8.5) "points"
9.6) "200"
10.redis 127.0.0.1:6379>
以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis HMSET, HEGTALL 命令,user:1 为键值。
每个 hash 可以存储 2^32 - 1 键值对(40多亿)。
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
实例
redis 127.0.0.1:6379> lpush shouce.ren redis
2.(integer) 1
3.redis 127.0.0.1:6379> lpush shouce.ren mongodb
4.(integer) 2
5.redis 127.0.0.1:6379> lpush shouce.ren rabitmq
6.(integer) 3
7.redis 127.0.0.1:6379> lrange shouce.ren 0 10
8.1) "rabitmq"
9.2) "mongodb"
10.3) "redis"
11.redis 127.0.0.1:6379>
列表最多可存储 2^32 - 1 元素 (4294967295, 每个列表可存储40多亿)。
Set(集合)
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
sadd 命令
添加一个string元素到,key对应的set集合中,成功返回1,如果元素已经在集合中返回0,key对应的set不存在返回错误。
sadd key member
实例
redis 127.0.0.1:6379> sadd shouce.ren redis
2.(integer) 1
3.redis 127.0.0.1:6379> sadd shouce.ren mongodb
4.(integer) 1
5.redis 127.0.0.1:6379> sadd shouce.ren rabitmq
6.(integer) 1
7.redis 127.0.0.1:6379> sadd shouce.ren rabitmq
8.(integer) 0
9.redis 127.0.0.1:6379> smembers shouce.ren
10.
11.1) "rabitmq"
12.2) "mongodb"
13.3) "redis"
注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个成员)。
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
实例
127.0.0.1:6379> zadd kgc 1 java
(integer) 1
127.0.0.1:6379> zadd kgc 2 mysql
(integer) 1
127.0.0.1:6379> zadd kgc 3 hadoop
integer) 1
127.0.0.1:6379> zadd kgc 4 hive
(integer) 1
127.0.0.1:6379> zrange kgc 0 -1
1) "java"
2) "mysql"
3) "hadoop"
4) "hive"