Redis是一个内存数据库,只用硬盘来进行持久化。

Mongodb是半内存数据库

Mysql是硬盘数据库

1. Redis启动

  安装好了之后。运行redis-3.2.8/src/下的redis-server

运行redis--cli客户端,检查redis是否在工作:

lijinxu@lijinxu-virtual-machine:~$ redis-cli 

这将打开一个redis提示,如下所示

redis 127.0.0.1:>

在上面的提示中,127.0.0.1是计算机的IP地址,6379是运行Redis服务器的端口。 现在键入以下PING命令。

redis 127.0.0.1:> ping
PONG

这表明Redis已成功在您的计算机上安装了。

2. Redis配置

在Redis中,在Redis的根目录下有一个配置文件(redis.conf)。当然您可以通过Redis CONFIG命令获取和设置所有的Redis配置。

语法
以下是Redis中的CONFIG命令的基本语法。

redis 127.0.0.1:> CONFIG GET CONFIG_SETTING_NAME

3. Redis数据类型

字符串 string

Redis中的字符串是一个字节序列。Redis中的字符串是二进制安全的,这意味着它们的长度不由任何特殊的终止字符决定。因此,可以在一个字符串中存储高达512兆字节的任何内容。

示例

redis 127.0.0.1:6379> set name "yiibai.com"
OK
redis 127.0.0.1:6379> get name
"yiibai.com"
Shell

在上面的示例中,setget是Redis命令,name是Redis中使用的键,yiibai.com是存储在Redis中的字符串的值。

注 - Redis命令不区分大小写,如SET,Setset都是同一个命令。字符串值的最大长度为 512MB。

可以看到字符串依然是键值对形式

散列/哈希 dict

执行以下代码,插入一条

127.0.0.1:> hmset ukey username "lijinxu" password "passwd123" points 

调用命令

hgetall key

查看整个键值对

127.0.0.1:> hgetall ukey

) "username"
) "lijinxu"
) "password"
) "passwd123"
) "points"
) ""

可以看到就是使用键值对插入 username -> "lijinxu"  ;   password -> "passwd123" ....

当重复插入username -> "lijinxu"  返回ok,但是列表中不会有重复数据。

调用 hget key field 命令查看 key 下的 某一个键的值:

127.0.0.1:> hset person name jack
(integer)
127.0.0.1:> hset person age
(integer)
127.0.0.1:> hset person sex famale
(integer)
127.0.0.1:> hgetall person
) "name"
) "jack"
) "age"
) ""
) "sex"
) "famale"
127.0.0.1:> hkeys person
) "name"
) "age"
) "sex"
127.0.0.1:> hvals person
) "jack"
) ""
) "famale"
127.0.0.1:> hget ukey password
"passwd123"

列表 list

redis 127.0.0.1:> lpush alist redis
(integer)
redis 127.0.0.1:> lpush alist mongodb
(integer)
redis 127.0.0.1:> lpush alist sqlite
(integer)
redis 127.0.0.1:> lrange alist ) "sqlite"
) "mongodb"
) "redis"
127.0.0.1:> lpush alist v1
(integer)
127.0.0.1:> lpush alist v1
(integer)
127.0.0.1:> lpush alist v1
(integer)
127.0.0.1:> LRANGE alist -
) "v1"
) "v1"
) "v1"

注意:列表里面是可以重复的。

列表的最大长度为2^32 - 1个元素(4294967295,每个列表可容纳超过40亿个元素)。

删除列表

127.0.0.1:> DEL alist
(integer)
127.0.0.1:> LRANGE alist
(empty list or set)

集合 set

redis集合是字符串的无序集合。在Redis中,您可以添加,删除和测试成员存在的时间O(1)复杂性。

redis 127.0.0.1:> sadd yiibailist redis
(integer)
redis 127.0.0.1:> sadd yiibailist mongodb
(integer)
redis 127.0.0.1:> sadd yiibailist sqlite
(integer)
redis 127.0.0.1:> sadd yiibailist sqlite
(integer)
redis 127.0.0.1:> smembers yiibailist ) "sqlite"
) "mongodb"
) "redis"

注意 - 在上面的示例中,sqlite被添加了两次,但是由于集合的唯一属性,所以它只算添加一次。

一个集合中的最大成员数量为2^32 - 1(即4294967295,每个集合中元素数量可达40亿个)个。

可排序集合 map

  Redis可排序集合类似于Redis集合,是不重复的字符集合。 不同之处在于,排序集合的每个成员都与分数相关联,这个分数用于按最小分数到最大分数来排序的排序集合。虽然成员是唯一的,但分数值可以重复。

示例

redis 127.0.0.1:> zadd yiibaiset  redis
(integer)
redis 127.0.0.1:> zadd yiibaiset mongodb
(integer)
redis 127.0.0.1:> zadd yiibaiset sqlite
(integer)
redis 127.0.0.1:> zadd yiibaiset sqlite
(integer)
redis 127.0.0.1:> ZRANGEBYSCORE yiibaiset ) "mongodb"
) "redis"
) "sqlite"

因为 ‘sqlite‘ 的排序值是 1 ,其它两个元素的排序值是 0 ,所以 ‘sqlite‘ 排在最后一个位置上。

总结:

  可以看到不管是任何 形式的数据的组织形式都是键值对。所以,redis就是一个键值对数据类型的非结构化数据库。

Redis基础---5个基本数据结构(比较性记忆)的更多相关文章

  1. Redis 02: redis基础知识 + 5种数据结构 + 基础操作命令

    Redis基础知识 1).测试redis服务的性能: redis-benchmark 2).查看redis服务是否正常运行: ping 如果正常---pong 3).查看redis服务器的统计信息: ...

  2. Redis基础(一)数据结构与数据类型

    Redis数据结构 Redis一共有六种数据结构,分别是简单动态字符串.链表.字典.跳表.整数集合.压缩列表. 简单动态字符串(SDS) Redis只会使用C字符串作为字面量,在大多数情况下,Redi ...

  3. redis 基础数据结构实现

    参考文献 redis数据结构分析 Skip List(跳跃表)原理详解 redis 源码分析之内存布局 Redis 基础数据结构与对象 Redis设计与实现-第7章-压缩列表 在redis中构建了自己 ...

  4. 1.基础: 万丈高楼平地起——Redis基础数据结构 学习记录

    <Redis深度历险:核心原理和应用实践>1.基础: 万丈高楼平地起——Redis基础数据结构 学习记录http://naotu.baidu.com/file/b874e2624d3f37 ...

  5. redis基础数据结构及编码方式

    redis基础数据结构和编码方式 一.基础数据结构 1)简单动态字符串 2)双端链表 3)字典 4)跳跃表 5)整数集合 6)压缩列表 二.对象类型与编码 在redis的数据库中创建一个新的键值对时, ...

  6. Redis基础数据结构-基于2.8

    SDS SDS是Redis中String的底层数据结构,数据结构如下,SDS保留了传统的C字符串表达方式即数组的最后一个元素是'/0'结尾.此外还添加了两个字段len和free,其中len表示字符串长 ...

  7. Redis 基础数据结构与对象

    Redis用到的底层数据结构有:简单动态字符串.双端链表.字典.压缩列表.整数集合.跳跃表等,Redis并没有直接使用这些数据结构来实现键值对数据库,而是基于这些数据结构创建了一个对象系统,这个系统包 ...

  8. Redis基础01-redis的数据结构

    参考书:<redis设计与实现> Redis虽然底层是用C语言写的,但是底层的数据结构并不是直接使用C语言的数据结构,而是自己单独封装的数据结构: Redis的底层数据结构由,简单动态字符 ...

  9. windows下使用redis,Redis入门使用,Redis基础命令

    windows下使用redis,Redis入门使用,Redis基础命令 >>>>>>>>>>>>>>>> ...

随机推荐

  1. POJ 3083_Children of the Candy Corn

    题意: 给定迷宫图,求出一个人从入口进,从出口出,所走过的最短路径以及分别沿着左手边和右手边的墙走出迷宫所走过的方格数. 分析: bfs求最短路 对于沿左右两边的墙走的情况,记录好行走的方向及相对应的 ...

  2. [bzoj1895][Pku3580]supermemo_非旋转Treap

    supermemo bzoj-1895 Pku-3580 题目大意:给定一个n个数的序列,需支持:区间加,区间翻转,区间平移,单点插入,单点删除,查询区间最小值. 注释:$1\le n\le 6.1\ ...

  3. cogs——619. [金陵中学2007] 传话

    619. [金陵中学2007] 传话 ★★   输入文件:messagez.in   输出文件:messagez.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] 兴趣小 ...

  4. oracle删除表前先判断表是否存在

     DECLARE  numbe NUMBER;BEGIN  SELECT COUNT(1)    INTO numbe    FROM USER_TABLES   WHERE TABLE_NAME = ...

  5. ecstore

  6. 《软件project》——编码

       编码的目的是使用选定的程序设计语言,把模块的过程描写叙述翻译为用该语言书写的源程序. 源程序应该正确可靠.简明清晰,并且具有较高的效率.在编程的步骤中,要把软件具体设计的表达式翻译成为编程语言的 ...

  7. 托管C++线程锁实现 c++11线程池

    托管C++线程锁实现   最近由于工作需要,开始写托管C++,由于C++11中的mutex,和future等类,托管C++不让调用(报错),所以自己实现了托管C++的线程锁. 该类可确保当一个线程位于 ...

  8. MySQL-数据表锁定

    MySQL允许客户端会话明确获取表锁,以防止其他会话在特定时间段内访问表.客户端会话只能为自己获取或释放表锁.它不能获取或释放其他会话的表锁. 创建一个数据表: CREATE DATABASE IF ...

  9. 图片存储系统TFS

    1 TFS和GFS比较 1.1 GFS的应用场景 第一,百万级别的文件,并且是大文件,文件都是100MB以上,1G级别的文件很常见. 第二,集群是建立在商业计算机之上,并不可靠,监控各个节点的状态,当 ...

  10. YTU 2697: 血型统计

    2697: 血型统计 时间限制: 1 Sec  内存限制: 128 MB 提交: 405  解决: 164 题目描述 黑猫警长在犯罪现场发现了一些血迹,现已经委托检验机构确定了血型,需要统计各种血型的 ...