赞
踩
Redis 是一个开源(BSD 许可)的,使用 C 语言编写的,支持网络交互的, 内存中的 Key-Value 数据结构存储系统,它可以用作数据库、缓存和消息中间 件。它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列 表(lists), 集合(sets), 有序集合(sorted sets)。 redis 的作者,叫 Salvatore Sanfilippo,来自意大利的西西里岛,目前供 职于 Pivotal 公司。他使用的网名是 antirez。 目前,Vmware 在资助着 redis 项目的开发和维护。
关系型数据库
采用关系模型来组织数据的数据库,关系模型就是二维表格模型。一张二维 表的表名就是关系,二维表中的一行就是一条记录,二维表中的一列就是一个字 段
优点
容易理解
使用方便,通用的 sql 语言
易于维护,丰富的完整性(实体完整性、参照完整性和用户定义的完整性)
大大降低了数据冗余和数据不一致的概率缺点
缺点
磁盘 I/O 是并发的瓶颈
海量数据查询效率低横向扩展困难,无法简单的通过添加硬件和服务节点来扩展性能和负载能力,
当需要对数据库进行升级和扩展时,需要停机维护和数据迁移
多表的关联查询以及复杂的数据分析类型的复杂 sql 查询,性能欠佳。因为要 保证 ACID(事务)
非关系型数据库
非关系型,分布式,一般不保证遵循 ACID 原则的数据存储系统。键值对存储, 结构不固定。
优点
根据需要添加字段,不需要多表联查。仅需 id 取出对应的 value
严格上讲不是一种数据库,而是一种数据结构化存储方法的集合
缺点
只适合存储一些较为简单的数据
不适合复杂查询的数据
不适合持久存储海量数据
下载:https://redis.io/download
cd /usr/local/src/ 在线下载 或者 在官网下载
wget https://download.redis.io/releases/redis-6.2.4.tar.gz
或者 上传
解压: tar -zxvf redis-6.0.8.tar.gz
cd redis-6.0.8
预编译: make
预编译: make
创建文件: mikdir -p /usr/local/redis
安装到指定目录: make install PREFIX=/usr/local/redis
进入安装文件 bin 目录:cd /usr/local/redis/bin
./redis-server 启动服务
设置
从 redis 的源码目录中复制 redis.conf 到 redis 的安装目录
cp redis.conf /usr/local/redis/bin/
修改 redis.conf 文件 vim redis.conf
1.后台运行: daemonize no 改为 daemonize yes.
2.设置密码:
requirepass 你的密码.
文件内查找: /你搜索的内容
回车
n 下一个
N 上一个.
3.注释 绑定的 id,默认只能本机访问,这样就可可以远程访问了
启动命令:
./redis-server redis.conf
查看 Redis 运行状态:
ps -ef | grep redis
进入客户端模式:
./redis-cli
输入密码
auth 密码
测试
ping (如果测试结果视屏则代表安装成功)
ctrl+c 退出客户端模式
redis 支持五种数据类型:
string(字符串)
hash(哈希)
list(列表)
set(集合 )
zset(sorted set:有序集合)
注:以下图片中的操作都是在linux进入了Redis客户端中进行的
String(字符串) :
string 是 redis 最基本的类型,一个 key 对应一个 value。 string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比 如 jpg 图片或者序列化的对象。 string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB
Hash(哈希)
redis hash 是一个键值(key=>value)对集合。
redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合 用于存储对象。
存的是字符串和字符串值之间的映射,比如一个用户要存储其全名、姓氏、年龄 等等,就很适合使用哈希。
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列 表的头部(左边)或者尾部(右边)。实例:
Set(集合)
Redis 的 Set 是 string 类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
sadd 命令
添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经 在集合中返回 0。
sadd key member
实例
以上实例中 rabbitmq 添加了两次,但根据集合内元素的唯一性,第二次插入 的元素将被忽略。最大的成员数为 232 - 1(4294967295, 每个集合可存储 40 多亿个成员)。
zset(sorted set:有序集合)
redis zset 和 set 一样也是 string 类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为 集合中的成员进行从小到大的排序。
zset 的成员是唯一的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应 score
zadd key score member
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。