干货--Redis 30分钟快速入门

本文详细介绍了Redis的环境搭建、数据类型、排序、事务、Pipeline、发布订阅、持久化和主从复制等核心概念,是学习Redis的全面教程。通过实例演示了如何使用Redis的多种操作,包括字符串、列表、集合、有序集合等数据类型,以及键的过期时间和主从复制的设置。此外,还探讨了Redis的持久化策略,包括快照和AOF文件,以及主从复制的优缺点。
摘要由CSDN通过智能技术生成

 

一、redis环境搭建2

二、redis学习笔记之数据类型3

三、redis学习笔记之排序11

四、redis学习笔记之事务16

五、redis学习笔记之pipeline20

六、redis学习笔记之发布订阅23

七、redis学习笔记之持久化28

八、redis学习笔记之主从复制30

九、redis学习笔记之虚拟内存31

 

一、 
redis环境搭建 

1.简介
       redis是一个开源的key-value数据库。它又经常被认为是一个数据结构服务器。因为它的value不仅包括基本的string类型还有list,set ,sorted sethash类型。当然这些类型的元素也都是string类型。也就是说list,set这些集合类型也只能包含
string 类型。你可以在这些类型上做很多原子性的操作。比如对一个字符value追加字符串(APPEND命令)。加加或者减减一个数字字符串(INCR命令,当 然是按整数处理的).可以对list类型进行push,或者pop元素操作(可以模拟栈和队列)。对于set类型可以进行一些集合相关操作(intersection union difference)memcache也有类似与++,--的命令。
不过memcachevalue只包括string类型。远没有redisvalue类型丰富。和memcahe一样为了性能。redis的数据通常都是放到内存中的。当然redis可以每间隔一定时间将内存中数据写入到磁盘以防止数据丢失。redis也支持主从复制机制(master-slave replication)。redis的其他特性包括简单的事务支持和 发布订阅(pub/sub)通道功能,而且redis配置管理非常简单。还有各种语言版本的开源客户端类库。
2.安装

3.0.7目前是最新稳定版
可以在linux下运行如下命令进行安装

$ tar xgzf redis-3.0.7.tar.gz
$ cd redis-3.0.7
$ make

make完后 redis-3.0.7目录下会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli
下面启动redis服务.

$./redis-server

注意这种方式启动redis 使用的是默认配置。也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动.

$ ./redis-server redis.conf

redis.conf是一个默认的配置文件。我们可以根据需要使用自己的配置文件。
启动redis服务进程后,就可以使用测试客户端程序redis-cliredis服务交互了.
比如

$ ./redis-cli
redis> set foo bar
OK
redis> get foo
"bar"

这里演示了getset命令操作简单类型value的例子。fookey ,bar是个string类型的value
linux的可以通过这个在线的来练习,当然在线版的很多管理相关的命令是不支持的。


3.java客户端hello,world
客户端jar包为 jedis

import redis.clients.jedis.Jedis;

public class Test1 {
    

    public static void main(String[] args) {
        // 连接本地的 Redis 服务
        Jedis jedis = new Jedis("169.254.173.100");
        System.out.println("Connection to server sucessfully");
        // 查看服务是否运行
        System.out.println("Server is running: " + jedis.ping());
        String keys = "name";
        jedis.del(keys);
        String vaule = jedis.set(keys, "tanggao");
        System.out.println(vaule);
    }

}

好了redis环境已经搭建好了。后面会写写redis的各种类型和类型相关的命令和一些具体的应用场景

 

二、 redis学习笔记之数据类型 

本文介绍下redis支持的各种数据类型包括string,list ,set ,sorted sethash

 

1. keys
redis本质上一个key-value db,所以我们首先来看看他的key.首先key也是字符串类型,但是key中不能包括边界字符
由于key不是binary safe的字符串,所以像"my key""mykey\n"这样包含空格和换行的key是不允许的
顺便说一下在redis内部并不限制使用binary字符,这是redis协议限制的。"\r\n"在协议格式中会作为特殊字符。
redis 1.2以后的协议中部分命令已经开始使用新的协议格式了(比如MSET)。总之目前还是把包含边界字符当成非法的key吧,
免得被bug纠缠。
   另外关于key的一个格式约定介绍下,object-type:id:field。比如user:1000:passwordblog:xxidxx:title
还有key的长度最好不要太长。道理很明显占内存啊,而且查找时候相对短key也更慢。不过也推荐过短的key
比如u:1000:pwd,这样的。显然没上面的user:1000:password可读性好。

下面介绍下key相关的命令
exits key 测试指定key是否存在,返回1表示存在,0不存在
del key1 key2 ....keyN  删除给定key,返回删除key的数目,0表示给定key都不存在
type key 返回给定keyvalue类型。返回none 表示不存在key,string字符类型,list链表类型 set无序集合类型...
keys pattern 返回匹配指定模式的所有key,下面给个例子
redis> set test dsf
OK
redis> set tast dsaf
OK
redis> set tist adff
OK
redis> keys t*
1. "tist"
2. "tast"
3. "test"
redis> keys t[ia]st
1. "tist"
2. "tast"
redis> keys t?st
1. "tist"
2. "tast"
3. "test"

randomkey 返回从当前数据库中随机选择的一个key,如果当前数据库是空的,返回空串
rename oldkey newkey 原子的重命名一个key,如果newkey存在,将会被覆盖,返回1表示成功,0失败。可能是oldkey不存在或者和newkey相同
renamenx oldkey newkey 同上,但是如果newkey存在返回失败
dbsize 返回当前数据库的key数量
expire key seconds key指定过期时间,单位是秒。返回1成功,0表示key已经设置过过期时间或者不存在
ttl key 返回设置过过期时间的key的剩余过期秒数-1表示key不存在或者没有设置过过期时间
select db-index 通过索引选择数据库,默认连接的数据库所有是0,默认数据库数是16个。返回1表示成功,0失败
move key db-index  key从当前数据库移动到指定数据库。返回1成功。0如果key不存在,或者已经在指定数据库中
flushdb 删除当前数据库中所有key,此方法不会失败。慎用
flushall 删除所有数据库中的所有key,此方法不会失败。更加慎用

2. string 类型
stringredis最基本的类型,而且string类型是二进制安全的。意思是redisstring可以包含任何数据。比如jpg图片或者序列化的对象
。从内部实现来看其实string可以看作byte数组,最大上限是1G字节。下面是string类型的定义。
struct sdshdr {
    long len;
    long free;
    char buf[];
};
buf是个char数组用于存贮实际的字符串内容。其实charc#中的byte是等价的,都是一个字节
lenbuf数组的长度,free是数组中剩余可用字节数。由此可以理解为什么string类型是二进制安全的了。因为它本质上就是个byte数组。
当然可以包含任何数据了。另外string类型可以被部分命令按int处理.比如incr等命令,下面详细介绍。还有redis的其他类型像list,set,sorted set hash
它们包含的元素与都只能是string类型。
如果只用string类型,redis就可以被看作加上持久化特性的memcached.当然redisstring类型的操作比memcached多很多啊。如下:

set key value 设置key对应的值为string类型的value,返回1表示成功,0失败
setnx key value 同上,如果key已经存在,返回0nx not exist的意思
get key 获取key对应的string,如果key不存在返回nil
getset key value 原子的设置key的值,并返回key的旧值。如果key不存在返回nil
mget key1 key2 ... keyN 一次获取多个key的值,如果对应key不存在,则对应返回nil。下面是个实验,首先清空当前数据库,然后
设置k1,k2.获取时k3对应返回nil
redis> flushdb
OK
redis> dbsize
(integer) 0
redis> set k1 a
OK
redis> set k2 b
OK
redis> mget k1 k2 k3
1. "a"
2. "b"
3. (nil)

mset key1 value1 ... keyN valueN 一次设置多个key的值,成功返回1表示所有的值都设置了,失败返回0表示没有任何值被设置
msetnx key1 value1 ... keyN valueN 同上,但是不会覆盖已经存在的key
incr key key的值做加加操作,并返回新的值。注意incr一个不是intvalue会返回错误,incr一个不存在的key,则设置key

  • 6
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值