redis简介

Redis是一个开源的,高性能的,基于键值对的缓存与存储系统,通过设置各种键值数据类型来适应不同场景下的缓存与存储需求。同事redis的诸多高层级功能使其可以胜任消息队列,任务队列等不同角色。

存储结构

Redis是REmote Dictionary Server(远程字典服务器)的缩写,它以字典结构存储数据,并允许其他应用通过TCP协议读写字典中的内容,目前为止redis支持的键值数据类型如下:字符串类型,散列类型,列表类型,集合类型,和有序集合类型。其中一个字符串类型键值允许存储的数据最大容量为521M.

内存存储与持久化

Redis数据库中的所有数据都存储在内存中。在一台普通的笔记本电脑上,Redis可以在一秒内读写超过10万个键值。

数据存储在内存也有问题比如断电。redis还提供了持久化的存储,既可以将内存的数据异步写入应哦按,同时不影响继续

提供服务。

功能丰富

Redis可以为每个键设置生存时间,生存时间到后期会自动删除,这一功能可以利用redis作为缓存系统来调用。

除此之外,redis的列表类型键可以用来实现队列,并且支持阻塞式读取,可以容易地实现一个高性能的优先级队列,同时在更高层上,redis还支持"发布/订阅"的消息模式,可以基于此构建聊天室。

redis的安装

参考 -----

redis命令行客户端

通过redis-cli向redis发送命令,

通过-h和-p自定义地址和端口号
$redis-cli -h 127.0.0.1 -p 6379

通过ping命令测试连接是否正常

$redis-cli PING
####状态回复
PONG
####错误回复
如果上述命令不存在或者存在格式错误,会返回以error开头的错误。如
reids>ERRORCOMMEND
输出
(error)ERR unknow command 'ERRORCOMMEND'

获取先输入redis-cli进入交互模式,然后自由输入命令,例如PING.

整数回复

返回递增后的键值,类似mysql最后的索引值

依次执行以下命令
redis-cli
127.0.0.1:6379> set foot bar
OK
127.0.0.1:6379> INCR foo
(integer) 1
127.0.0.1:6379> set foot bar
OK
127.0.0.1:6379> INCR foo
(integer) 2

可以看到每次插入一条数据返回值都跟着变化。

字符串回复

127.0.0.1:6379> set foot bar
OK
127.0.0.1:6379> get foo
"bar"
127.0.0.1:6379> set foo banana
OK
127.0.0.1:6379> get foo
"banana"
127.0.0.1:6379>

可以看到get命令可以获取foo的最新的键值。

字符串多行回复

127.0.0.1:6379> KEYS *
1) "proxies"
2) "foo"
3) "foot"

返回键名1是我之前执行的,3是之前foo打错了执行的。keys命令需要便利redis中的所有键,当键的数量较多时会影响性能,不建议生产环境中使用。

多行数据库

redis提供了多个来存储数据的字典,每个字典类型mysql的数据量,每个数据库对外都是以0开始递增,redis默认支持16个数据库,客户端连接到服务端时,redis默认使用0进行操作数据库,使用select可以根据数据库。比如选择1号数据库:

redis-cli
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> get foo
(nil)
127.0.0.1:6379[1]>

redis不支持自定义数据库的名字,每个数据库必须以编号命名。比如可以使用0号数据库存储某个应用生产环境的数据,1号数据库存储测试环境中的数据,需要注意的是不同的应用应该使用不同的redis实例redis也不支持为每个数据库设置不同的访问密码。

最重要的是redis实例中所有数据库的数据并不是完全隔离的,比如FLUSHALL可以清空一个redis实例中所有数据库中的数据。。由于redis非常轻量级,一个空的redis实例占用内存只有1MD左右,所以不用担心多个redis实例会额外占用很多内存。

几个基础命令

1.keys 见上面的例子

2.判断一个键是否存在

exists key 如果存在返回1 ,不存在返回0

0.0.1:6379> exists foo
(integer) 1
127.0.0.1:6379> exists foo2
(integer) 0
127.0.0.1:6379> exists foot
(integer) 1
127.0.0.1:6379>

3.删除键

del key [key ...]

可以删除一个或者多个空格间隔,返回值是删除的个数。del命令不支持通配符。

127.0.0.1:6379> set f1 1
OK
127.0.0.1:6379> set f3 1
OK
127.0.0.1:6379> set f2 1
OK
127.0.0.1:6379> keys *
1) "key"
2) "f1"
3) "proxies"
4) "f2"
5) "foot"
6) "foo"
7) "f3"
127.0.0.1:6379> del f1
(integer) 1
127.0.0.1:6379> del f2 f3
(integer) 2
127.0.0.1:6379>

3.获取键值的数据类型

type key

type命令用来获取键值类型,返回值可能是string,hash,list,set,zset(有序集合)。

127.0.0.1:6379> set test 1
OK
127.0.0.1:6379> type test
string
127.0.0.1:6379> lpush test2 2
(integer) 1
127.0.0.1:6379> type test2
list
127.0.0.1:6379>

lpush命令是向指定的列表类型键中增加一个元素,如果不存在则创建。后面详解。

读取键值

get key

根据键获取其值。

127.0.0.1:6379> get fo
(nil)
127.0.0.1:6379> get foo
"banana"
127.0.0.1:6379>

不存在的时候返回nil.

递增数字

INCR key

增加指定的整数

INCRBY key increment

incrby和incr命令效果差不多,区别是incrby可以指定增加的数字

127.0.0.1:6379> incrby bar 2
(integer) 2
127.0.0.1:6379> incrby bar 5
(integer) 7
127.0.0.1:6379> incr bar
(integer) 8
127.0.0.1:6379> incr bar
(integer) 9
127.0.0.1:6379>

增加指定的浮点数

incrbyfloat key inrement

这个命令类似上面两个只不过是可以传递一个浮点数而已

127.0.0.1:6379> incrbyfloat bar 3.14
"12.140000000000001"
127.0.0.1:6379> incrbyfloat bar 3.14e+9
"3140000012.1399999"
127.0.0.1:6379>

减少指定的整数

有增加就有减少

decr和decrby和增加的用法一样,只不过是键值递减。

decrby key 4相当于incrbu key -4

向尾部追加值

向键值的末尾加字符串,如果不存在就是相当于set key value

127.0.0.1:6379> append bar "345"
(integer) 21
127.0.0.1:6379> get bar
"3140000012.1399999345"
127.0.0.1:6379>
127.0.0.1:6379> append asd "hello dj"
(integer) 8
127.0.0.1:6379> get asd
"hello dj"
127.0.0.1:6379>

获取字符串长度

STRLEN key

返回键值长度,不存在返回0.

127.0.0.1:6379> set key "￀￷ᄎᆭ"
OK
127.0.0.1:6379> strlen key
(integer) 4
127.0.0.1:6379> set key "ᅣ ̄채"
OK
127.0.0.1:6379> strlen key
(integer) 4
127.0.0.1:6379>

同时设置多个键值

Mget key/mset key value

mget/mset和get/set相似,前者可以获取/设置多个值。

(integer) 4
127.0.0.1:6379> mget bar foo
1) "3140000012.1399999345"
2) "banana"
127.0.0.1:6379> mset a 1 b 2
OK
127.0.0.1:6379>

位操作

getbit key offset

setbit key offset value

bitcount key [start][end]

bitop operation destkey key [key ....]

一个字节由8个二进制位组成,redis提供了以上四个命令可以直接对二进制进行操作。

redis学习笔记之redis简介的更多相关文章

  1. Redis学习笔记之Redis单机,伪集群,Sentinel主从复制的安装和配置

    0x00 Redis简介 Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure server). Redis的键值 ...

  2. Redis学习笔记(4) Redis事务、生存时间及排序

    1. Redis事务 Redis中的事务(transaction)是一组命令的集合,一个事务中的命令要么都执行,要么都不执行.事务的原理是先将属于一个事务的命令发送给Redis,然后再让Redis依次 ...

  3. Redis学习笔记(1) Redis介绍及基础

    1. Redis的特性 (1) 存储结构 Redis(Remote Dictionary Server,远程字典服务器)是以字典结构存储数据,并允许其他应用通过TCP协议读写字典中的内容.Redis支 ...

  4. StackExchange.Redis学习笔记(一) Redis的使用初探

    Redis Redis将其数据库完全保存在内存中,仅使用磁盘进行持久化. 与其它键值数据存储相比,Redis有一组相对丰富的数据类型. Redis可以将数据复制到任意数量的从机中 Redis的安装 官 ...

  5. redis学习笔记(三)——redis的命令大全总结

    总结了一些redis五种存储类型的常用命令以及一些通用操作命令,不是很全,是在学习的时候将学到的做了个汇总,使用的时候可以查一下. 笔记写在表格里面了,不好粘贴.......后面的直接截图了..... ...

  6. Redis学习笔记(3) Redis基础类型及命令之二

    1. 集合类型 集合类型与列表类型有很多相似之处,但二者的区别在于:前者具有唯一性,但不具有有序性:后者具有有序性,但不具有唯一性.集合类型的常用操作是向集合中加入或删除元素.判断某个元素是否存在等, ...

  7. Redis学习笔记~StackExchange.Redis实现分布式Session

    回到目录 对于多WEB的环境现在已经是必须的了,很难想像一台WEB服务器面对百万并发的响应,所以,我们需要多台WEB服务器集群合作,来缓解这种高并发,高吞吐的场景,而对于多WEB的场景又会有个问题出现 ...

  8. Redis学习笔记(2) Redis基础类型及命令之一

    1. 基础命令 (1) 获取符合规则的键名列表 格式为:KEYS pattern 其中pattern表示支持通配符 # 建立一个名为bar的键 > SET bar OK # 获取Redis所有键 ...

  9. Redis学习笔记之Redis基本数据结构

    Redis基础数据结构 Redis有5种基本数据结构:String(字符串).list(列表).set(集合).hash(哈希).zset(有序集合) 字符串string 字符串类型是Redis的va ...

随机推荐

  1. P2303 [SDOi2012]Longge的问题

    题目描述 Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). 输入输出格式 输入格式: 一 ...

  2. TreeMap源码剖析

    原文  http://blog.csdn.net/chdjj/article/details/38782221 主题 源码分析红黑树 注:以下源码基于jdk1.7.0_11 之前介绍了一系列Map集合 ...

  3. Joseph's Problem UVALive - 3521(等差数列的应用)

    题意:给定n, k,求出∑ni=1(k mod i) 思路:由于n和k都很大,直接暴力是行不通的,然后在纸上画了一些情况,就发现其实对于k/i相同的那些项是形成等差数列的,于是就可以把整个序列进行拆分 ...

  4. opencv图片转幻灯片视频

    /*g++ *.cpp `pkg-config --cflags --libs opencv` -std=c++11*/ #include <opencv2/opencv.hpp> usi ...

  5. Linux下cp ~中关于“~”的疑问

    目的:将wi主文件夹下的.bashrc复制到/tmp,并更名为bashrc.对于书上的代码上加“~”存在疑问. cp ~/.bashrc /tmp/bashrc 对命令进行了以下尝试: 为什么不加“~ ...

  6. 20135319zl软件破解报告

    编写一个简单的C程序.要求只有输入a,才能通过. 现在,使用objdump –d po反汇编这个程序 找到main函数,可以发现movb $0x61,0x1f(%esp)这句语句中是将字符a(对应0x ...

  7. opencv 应用程序无法正常启动(0xooooo7b)

    #include<iostream> #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui ...

  8. 主角场景Shader效果:光影

    基本思路:unity有一种很容易实现光影效果的神器,那就是unity自带的projector. 首先需要用到两张贴图: 一张投影需要的光圈贴图,如下: 一张根据远近距离显示暗淡的贴图(左至右,白渐变黑 ...

  9. webservice的接口协议(HTTPClient 、RestTemplate HttpURLConnection)

    HTTP协议时Internet上使用的很多也很重要的一个协议,越来越多的java应用程序需要通过HTTP协议来访问网络资源. HTTPClient提供的主要功能: 1.实现了所有HTTP的方法(GET ...

  10. vi的一些使用技巧

    1.vi 编辑器中跳到文件的第一行:键盘按下 小写 gg   vi 编辑器跳到文件最后一行:键盘按 shift + g (等于G) 跳转到当前行的第一个字符按0,跳转到当前行的最后一个字符按shift ...