Redis安装与详解

安装步骤

下载地址: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"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值