Redis简述

Redis 简单介绍

Redis 是全然开源免费的。遵守BSD协议,是一个高性能的key-value数据库。


Redis 与其它 key - value 缓存产品有下面三个特点:

  • Redis支持数据的持久化,能够将内存中的数据保持在磁盘中,重新启动的时候能够再次载入进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同一时候还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。

Redis 优势

  • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
  • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

  • 原子 – Redis的全部操作都是原子性的,同一时候Redis还支持对几个操作全并后的原子性执行。
  • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

Redis与其它key-value存储有什么不同?

  • Redis有着更为复杂的数据结构而且提供对他们的原子性操作。这是一个不同于其它数据库的进化路径。

    Redis的数据类型都是基于基本数据结构的同一时候对程序猿透明,无需进行额外的抽象。

  • Redis执行在内存中可是能够持久化到磁盘。所以在对不同数据集进行快速读写时须要权衡内存,应为数据量不能大于硬件内存。

    在内存数据库方面的还有一个长处是, 相比在磁盘上同样的复杂的数据结构,在内存中操作起来非常easy,这样Redis能够做非常多内部复杂性非常强的事情。 同一时候,在磁盘格式方面他们是紧凑的以追加的方式产生的,由于他们并不须要进行随机訪问。


redis的安装

下载安装包。博主採用的是redis-3.0.5.tar.gz,能够在这里下载.
安装步骤:

tar -zvxf redis-3.0.5.tar.gz
cd redis-3.0.5
make 

redis服务端开启

./redis-server

开启之后例如以下图所看到的:
这里写图片描写叙述

这样的方式是启动的redis使用的是默认配置,也能够通过启动參数考古redis使用指定配置文件:

./redis-server [redis.conf的路径]

假设改动redis.conf,採用redis默认的redis.conf文件, redis默认仅仅能通过127.0.0.1:6379这个地址訪问,这样就仅仅能在本机上操作了。假设想要远程操作就不可行了。

这里须要改动redis.conf这个配置文件,在配置文件里加入相应的ip地址,这里假如加入ip地址:10.10.195.112。仅仅需在redis.conf这个配置文件里加入:

bind 10.10.195.112
bind 127.0.0.1

这样就能够远程訪问redisserver了(先配置。后开启redis服务)。

redisclient连接

./redis-cli    (本地)
./redis-cli -h [host] -p [port] -a [password] (远程server)

Jedis开发

使用java开发redis,博主使用的是jedis,须要引入jedis的jar,能够在这里下载。

还须要commons-pool.jar包
这里写图片描写叙述

连接

    Jedis jedis = new Jedis("10.10.195.112");
    System.out.println(jedis.ping());

输出:PONG

操作字符串

        jedis.set("name", "zzh");
        System.out.println(jedis.get("name"));

输出:zzh

操作列表

        jedis.lpush("nblist", "jj");
        jedis.lpush("nblist", "jj");
        jedis.lpush("nblist", "yy");
        jedis.lpush("nblist", "qq");
        List<String> list = jedis.lrange("nblist", 0, -1);
        int length = list.size();
        for(int i=0;i<length;i++)
        {
            System.out.println(list.get(i));
        }

输出:

qq
yy
jj
jj

获取redis中全部的键

    Set<String> set = jedis.keys("*");
    for(String key : set)
    {
        System.out.println(key);
    }

输出:

nam
name
tutorial
list
tutorial-list
nblist
tutoriallist
keyname
user
listt
zsetkey
hash-key

Redis经常使用命令

1 连接操作命令

  • quit:关闭连接(connection)
  • auth:简单密码认证
  • help cmd: 查看cmd帮助。比如:help quit

2 持久化

  • save:将数据同步保存到磁盘
  • bgsave:将数据异步保存到磁盘
  • lastsave:返回上次成功将数据保存到磁盘的Unix时戳
  • shutdown:将数据同步保存到磁盘,然后关闭服务

3 远程服务控制

  • info:提供server的信息和统计
  • monitor:实时转储收到的请求
  • slaveof:改变复制策略设置
  • config:在执行时配置Redisserver

4 对key操作的命令

  • exists(key):确认一个key是否存在
  • del(key):删除一个key
  • type(key):返回值的类型
  • keys(pattern):返回满足给定pattern的全部key
  • randomkey:随机返回key空间的一个
  • keyrename(oldname, newname):重命名key
  • dbsize:返回当前数据库中key的数目
  • expire:设定一个key的活动时间(s)
  • ttl:获得一个key的活动时间
  • select(index):按索引查询
  • move(key, dbindex):移动当前数据库中的key到dbindex数据库
  • flushdb:删除当前选择数据库中的全部key
  • flushall:删除全部数据库中的全部key

5 String

  • set(key, value):给数据库中名称为key的string赋予值value
  • get(key):返回数据库中名称为key的string的value
  • getset(key, value):给名称为key的string赋予上一次的value
  • mget(key1, key2,…, key N):返回库中多个string的value
  • setnx(key, value):加入string,名称为key。值为value
  • setex(key, time, value):向库中加入string,设定过期时间time
  • mset(key N, value N):批量设置多个string的值
  • msetnx(key N, value N):假设全部名称为key i的string都不存在
  • incr(key):名称为key的string增1操作
  • incrby(key, integer):名称为key的string添加integer
  • decr(key):名称为key的string减1操作
  • decrby(key, integer):名称为key的string降低integer
  • append(key, value):名称为key的string的值附加value
  • substr(key, start, end):返回名称为key的string的value的子串

6 List

  • rpush(key, value):在名称为key的list尾加入一个值为value的元素
  • lpush(key, value):在名称为key的list头加入一个值为value的 元素
  • llen(key):返回名称为key的list的长度
  • lrange(key, start, end):返回名称为key的list中start至end之间的元素
  • ltrim(key, start, end):截取名称为key的list
  • lindex(key, index):返回名称为key的list中index位置的元素
  • lset(key, index, value):给名称为key的list中index位置的元素赋值
  • lrem(key, count, value):删除count个key的list中值为value的元素
  • lpop(key):返回并删除名称为key的list中的首元素
  • rpop(key):返回并删除名称为key的list中的尾元素
  • blpop(key1, key2,… key N, timeout):lpop命令的block版本号。

  • brpop(key1, key2,… key N, timeout):rpop的block版本号。

  • rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素。并将该元素加入到名称为dstkey的list的头部

7 Set

  • sadd(key, member):向名称为key的set中加入元素member
  • srem(key, member) :删除名称为key的set中的元素member
  • spop(key) :随机返回并删除名称为key的set中一个元素
  • smove(srckey, dstkey, member) :移到集合元素
  • scard(key) :返回名称为key的set的基数
  • sismember(key, member) :member是否是名称为key的set的元素
  • sinter(key1, key2,…key N) :求交集
  • sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
  • sunion(key1, (keys)) :求并集
  • sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
  • sdiff(key1, (keys)) :求差集
  • sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
  • smembers(key) :返回名称为key的set的全部元素
  • srandmember(key) :随机返回名称为key的set的一个元素

8 Hash

  • hset(key, field, value):向名称为key的hash中加入元素field
  • hget(key, field):返回名称为key的hash中field相应的value
  • hmget(key, (fields)):返回名称为key的hash中field i相应的value
  • hmset(key, (fields)):向名称为key的hash中加入元素field
  • hincrby(key, field, integer):将名称为key的hash中field的value添加integer
  • hexists(key, field):名称为key的hash中是否存在键为field的域
  • hdel(key, field):删除名称为key的hash中键为field的域
  • hlen(key):返回名称为key的hash中元素个数
  • hkeys(key):返回名称为key的hash中全部键
  • hvals(key):返回名称为key的hash中全部键相应的value
  • hgetall(key):返回名称为key的hash中全部的键(field)及其相应的value

关于Jedis的具体使用将在兴许更新,欢迎关注我的博客~

posted @ 2017-08-08 18:34  wzjhoutai  阅读(227)  评论(0编辑  收藏  举报