redis命令

1.安装篇

a) Window版本64位下载地址

https://github.com/microsoftarchive/redis/releases

下载完成后

Windows 解压 redis压缩包

启动redis-server.exe

b)  Linux版本下载

https://redis.io/download

下载完成之后

Linux 解压 tar-zxvf  redis 压缩包

启动redis-server.exe

2.安装redis集群篇

暂时不考虑

3.命令篇

远程服务执行命令

语法:redis-cli -h host -p port -a password

          host:ip

          port:端口

          password: 密码

示例:redis-cli -h 127.0.0.1 -p 6379 -a "wll123"

redis 键key

redistext:0>set run redis

键为run  值为redis   set语法

给键一个redis的值

redistext:0>del run

删除名为run的键key

redistext:0>dump run

序列化给定的key并返回被序列化的值

redistext:0>exists key

返回1为存在返回0不存在

redistext:0>expire run 10

设置key的过期时间,10的单位为秒

redistext:0>pexpire run 1000

设置key的过期时间以毫秒计

redistext:0>move wll 1

移动当前的key到指定的db中

redistext:0>select 1

切换库 

redistext:1>persist wll

移除当前ley的过期时间

redistext:1>randomkey

随机返回当前库的key

redistext:1>rename wll gyx

修改当前的key名字  库中若是有  替换库中的key

redistext:1>renamenx wll gyx

修改当前key的名字 库中没有时才会修改成功

redistext:1>type wll

返回key的存储类型

4.类型篇

  4.1Redis字符串(String)

redistext:1>set wll 2365900668

添加key为wll 值为2365900668

redistext:1>get wll

获取key为wll的val值

redistext:1>getrange wll 2 5

获取wll的指定字符  2 字符开始   5字符结束

redistext:1>getset wll 93075627

给定key为wll的一个新的值  返回旧的值

redistext:1>getbit wll 11

例如java char值得取值范围 如何把a变成b  修改char值

redistext:1>mget wll gyx

获取所有给定的key

redistext:1>setnx job kil

只有设置的key值不存在时才会为key设置指定的值   (set区别)

redistext:1>strlen wll

返回key的长度

redistext:1>mset key1 wll key2 gyx

设置一个或者多个key-val对

redistext:1>append wll 111

APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾 (值是字符串)

  4.2Redis哈希(hash)

Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。

Redis 中每个 hash 可以存储 2的32次方- 1 键值对(40多亿)。

命令:

redistext:1>hmset run wll "瞬发" gyx "mhg"

同时将多个field-value(域-值)对设置到哈希表的key中 key为run  wll gyx 域-值 redistext:1>hmget run wll gyx

获取 run中的wll gyx域中的值

redistext:1>hdel run wll

删除一个或者多个hash表字段

redistext:1>hexists run gyx

查看hash表key中,指定的字段是否存在

redistext:0>hset site redis redis.com

添加site hash表中添加key为redis val为redis.com 

redistext:0>hget site redis

获取 site hash表中key为redis的value值

redistext:0>hkeys site

获取所有hash表中的所有字段

redistext:0>hlen site

获取hash表字段的数量

redistext:0>hvals site

获取hash表中所有的值

  4.3Redis列表(list)、

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)

一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

redistext:0>blpop wll 10

移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

redistext:0>brpop wll 10

移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

redistext:0>lindex wll 0

通过索引获取列表元素

redistext:0>linsert wll before "age" "pipi"

命令用于在列表的元素前或者后插入元素。当指定元素不存在于列表中时,不执行任何操作。

redistext:0>llen wll

获取列表的长度

redistext:0>lpop wll

移除并获取列表的第一个元素

redistext:0>lpush wll ju ku

将一个或多个值插入到列表头部。如果 key不存在,一个空列表会被创建并执行 LPUSH操作。当key存在但不是列表类型时,返回一个错误。

redistext:0>lrem wll -4 aa

根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。

    count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。

    count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。

    count = 0 : 移除表中所有与 VALUE 相等的值。

 

redistext:0>lpushx wll jui

将一个值插入到已存在的列表头部

redistext:0>lset wll 0 kij

向列表的指定位置添加值

redistext:0>rpush wll ok ok

列表添加一个或者多个值与lpush区别 lpush添加头部

4.4redis集合(set)

Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

命令:

redistext:0>sadd buba wll

向集合中添加一个或者多个成员

redistext:0>smembers buba

查看集合的成员

redistext:0>scard buba

获取集合的成员数

redistext:0>sdiff key1 key2

返回给定所有集合的差集

redistext:0>sinter key1 key2

返回交集数据

redistext:0>sismember key1 a

判断该成员是不是集合中的成员 是返回1

redistext:0>smembers key1

返回该集合中的所有成员

redistext:0>spop key1

移除并返回集合中的随机元素

redistext:0>srandmember key1

返回集合中一个随机元素

redistext:0>sunion key1 key2

返回给定集合的并集

SUNIONSTORE destination key1 [key2] 

所有给定集合的并集存储在 destination 集合中

  4.5有序集合(sorted set)

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

命令:

zadd  添加元素

了解

5.redis数据备份和恢复

备份数据

Redis中save命令用于创建当前数据库的备份

语法:redistext:0>save 

恢复数据

如果需要恢复数据,只需将备份文件(dump.rdb) 移动到 redis 安装目录并启动服务即可。获取redis目录可以使用CONFIG命令

redis 127.0.0.1:6379> CONFIG GET dir

1) "dir"

2) "/usr/local/redis/bin"

 

5.Redis安全

我们可以通过redis的配置文件设置密码参数这样客户端连接到redis服务就需要密码验证这样就可以使redis服务更加安全

查看是否设置密码

127.0.0.1:6379> CONFIG get requirepass

1) "requirepass"

2) ""

没有设置密码

Redis 密码runoob

 

Java示例

import redis.clients.jedis.Jedis;

 

public class RedisJava {

    public static void main(String[] args) {

        //连接本地的 Redis 服务

        Jedis jedis = new Jedis("localhost");

        System.out.println("连接成功");

        //查看服务是否运行

        System.out.println("服务正在运行: "+jedis.ping());

    }

}

 

 

 

import redis.clients.jedis.Jedis;

 

public class RedisStringJava {

    public static void main(String[] args) {

        //连接本地的 Redis 服务

        Jedis jedis = new Jedis("localhost");

        System.out.println("连接成功");

        //设置 redis 字符串数据

        jedis.set("runoobkey", "www.runoob.com");

        // 获取存储的数据并输出

        System.out.println("redis 存储的字符串为: "+ jedis.get("runoobkey"));

    }

}

 

 

import java.util.List;

import redis.clients.jedis.Jedis;

 

public class RedisListJava {

    public static void main(String[] args) {

        //连接本地的 Redis 服务

        Jedis jedis = new Jedis("localhost");

        System.out.println("连接成功");

        //存储数据到列表中

        jedis.lpush("site-list", "Runoob");

        jedis.lpush("site-list", "Google");

        jedis.lpush("site-list", "Taobao");

        // 获取存储的数据并输出

        List<String> list = jedis.lrange("site-list", 0 ,2);

        for(int i=0; i<list.size(); i++) {

            System.out.println("列表项为: "+list.get(i));

        }

    }

}

 

 

import java.util.Iterator;

import java.util.Set;

import redis.clients.jedis.Jedis;

 

public class RedisKeyJava {

    public static void main(String[] args) {

        //连接本地的 Redis 服务

        Jedis jedis = new Jedis("localhost");

        System.out.println("连接成功");

 

        // 获取数据并输出

        Set<String> keys = jedis.keys("*"); 

        Iterator<String> it=keys.iterator() ;   

        while(it.hasNext()){   

            String key = it.next();   

            System.out.println(key);   

        }

    }

}   

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章