Redis基础及入门
一. 什么是 Redis
Redis 是一个可基于内存,有着完备的持久化机制并以 Key-Value 形式存储的非关系型数据库。也称为数据结构服务器。
二. Redis 的优势。
支持数据的持久化,可以将内存中的数据保存在磁盘中,便于重启时再次使用。也就是我们平时说的缓存机制。
提供 list ,set ,zset ,hash 等数据结构的存储
支持数据的备份。即master-slave模式的数据备份。
三. 服务端的安装以及启动客户端
1. 安装并启动服务端
$ wget http://download.redis.io/releases/redis-3.2.9.tar.gz --获取到下载版本的网址
$ tar xzf redis-3.2.9.tar.gz --解压压缩包
$ cd redis-3.2.9 --打开目录
$ make --编译
$ src/redis-server redis.conf --启动服务端(使用默认端口6379)
启动成功后:
2. 启动客户端
$ src/redis-cli [-h 127.0.0.1 -p 6379]
PS: 查看连接信息
ps -ef | grep redis-3.2.9
修改端口号
vim redis.conf -- 打开redis.conf配置文件
(如果没有安装vim,系统会提示使用apt install vim 安装)
找到端口号所在位置,port 6379
shift + r 把原端口号替换为7000
:wq 保存修改并退出 至此,我们的端口号就变成7000啦
关闭服务器
1. $ src/redis-cli [-h 127.0.0.1 -p 6379] shutdown
2. kill -9 redis-server [使用管理员身份运行]
四. Redis命令及数据类型
1. 数据类型
String:
redis 的最基本类型。可以是任何数据,如字符串、整数、浮点,这些统称为元素。
示例:
常用命令:
SET key value :设置指定 key 的值
GET key :获取指定 key 的值
MGET key1 [ key2 ... ] :获取多个指定 key 的值
STRLEN key :返回 key 所存储的字符串值的长度
MSET key1 value1 [ key2 value2 ... ] :同时设置一个或多个 key -value
INCR key :将 key 中存储的数字 + 1
INCRBY key increment:给 key 中存储的数字加上指定数字( increment )
DECR key:将 key 中存储的数字 - 1
DECRBY key decrement:给 key 中存储的数字减去指定数字( increment )
APPEND key value :追加字符串
hash (哈希表):
key-value的散列组,是一个string类型的field和value的映射表,适合用于存储对象
示例:
常用命令:
HSET key field value:将哈希表 key 中的字段 field 的值设为 value
HGET key field:获取存储在哈希表中指定字段的值。
HLEN key:获取哈希表中字段的数量
HMGET key field1 [ field2 ... ]:获取全部字段的值
HMSET key field1 value1 [ field2 value2 ... ]:同时将多个 field-value (域-值)对设置到哈希表 key 中。
list:
一个有序的序列集合并且每个节点都包含了一个元素
示例:
常用命令:
LLEN key:获取列表长度
LPUSH key value1 [ value2 ... ]:将一个或多个值插入列表
RPOP key:移除并获取列表最后一个元素
LPOP key:移出并获取列表的第一个元素
LRANGE key start stop:获取列表指定范围内的元素
set:
存储各不相同的元素
示例:
常用命令:
SADD key member1 [ member2 ... ]:向集合添加一个或多个成员
SMEMBERS key member:返回集合中的所有成员
SREM key member1 [ member2 ... ]:移除集合中一个或多个成员
SCARD key:获取集合的成员数
SISMEMBER key member:判断 member 元素是否是集合 key 的成员
sort set (有续集合):
带分数的score-value有序集合,其中 value 是唯一的
示例:
常用命令:
ZADD key score1 member1 [ score2 member2 ... ]:向有序集合添加一个或多个成员,或修改已存在成员的分数
ZCARD key:获取有序集合的成员数
ZRANK key member:返回有序集合中指定成员的索引
ZRANGE key start stop [ WITHSCORES ]:通过索引区间返回有序集合指定区间内的成员
ZCOUNT key min max:计算在有序集合中指定区间分数的成员数
ZREM key member [ member2 ... ]:移除有序集合中的一个或多个成员
2. 命令
1. HyperLogLog
用来做基数统计的算法。无论输入元素的数量或体积有多大,都只占用固定的、很少的空间。且元素只用来计算基数,并不会存储元素本身。
常用命令:
PFADD key element [ element ... ]:添加指定元素到 HyperLogLog 中
PFCOUNT key [ key ... ]:返回给定 HyperLogLog 的基数估算值。
PFMERGE destkey soucekey [ sourcekey ... ]:将多个 HyperLogLog 合并为一个 HyperLogLog
2. 发布订阅(pub/sub)
一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。
客户端可以订阅任意数量的频道。
常用命令:
PSUBSCRIBE pattern [ pattern ... ]:订阅一个或多个符合给定模式的频道
PUBSUB subcommand [argument [ argument ... ] ]:查看订阅与发布系统状态。
PUBLISH channel message:将信息发送到指定的频道。
PUNSUBSCRIBE [ pattern [ pattern ... ] ]:退订所有给定模式的频道
SUBSCRIBE channel [ channel ... ]:订阅给定的一个或多个频道的信息。
UNSUBSCRIBE [ channel [ channel ... ] ]:指退订给定的频道。
3. 事物
可一次性执行多个命令且1. 事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。(事物是一个单独隔离操作) 2. 事务中的命令要么全部被执行,要么全部都不执行。(事务是一个原子操作)
执行过程:开始事物 --> 命令入队 --> 执行事务
常用命令:
MULTI:标记一个事物块的开始
EXEC:执行所有事务块内的命令。
DISCARD:取消事务,放弃执行事务块内的所有命令。
UNWATCH:取消 WATCH 命令对所有 key 的监视。
WATCH:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
4. 脚本
使用 Lua 解释器来执行脚本。
常用命令:
EVAL script numkeys key [key ...] arg [arg ...]:执行 Lua 脚本。
SCRIPT EXISTS script [ script ... ]:查看指定的脚本是否已经被保存在缓存当中。
SCRIPT FLUSH:从脚本缓存中移除所有脚本
SCRIPT KILL:杀死当前正在运行的 Lua 脚本。
SCRIPT LOAD script:将脚本 script 添加到脚本缓存中,但并不立即执行这个脚本
5. 连接
连接 redis 服务
常用命令:
AUTH password:验证密码是否正确
ECHO message:打印字符串
PING:查看服务是否运行
QUIT:关闭当前连接
SELECT index:切换到指定的数据库
6. 服务器
管理 redis 服务
常用命令:
BGSAVE:在后台异步保存当前数据库的数据到磁盘
CLIENT KILL [ip:port] [ID client-id]:关闭客户端连接
CLIENT LIST:获取连接到服务器的客户端连接列表
CLIENT GETNAME:获取连接的名称
CLIENT PAUSE timeout:在指定时间内终止运行来自客户端的命令
CLIENT SETNAME connection-name:设置当前连接的名称
CLUSTER SLOTS:获取集群节点的映射数组
CONFIG REWRITE:对启动 Redis 服务器时所指定的 redis.conf 配置文件进行改写
INFO [section]:获取 Redis 服务器的各种信息和统计数值
LASTSAVE:返回最近一次 Redis 成功将数据保存到磁盘上的时间,以 UNIX 时间戳格式表示
ROLE:返回主从实例所属的角色
SAVE:异步保存数据到硬盘
SHUTDOWN [NOSAVE] [SAVE]:异步保存数据到硬盘,并关闭服务器
SLAVEOF host port:将当前服务器转变为指定服务器的从属服务器(slave server)
7. 数据备份与恢复
8. 安全
9. 性能测试
10. 客户端连接
11. 管道技术
12. 分区
五. Redis 的配置文件(redis.conf)参数详解
六. 扩展内容
Redis基础及入门的更多相关文章
- windows下使用redis,Redis入门使用,Redis基础命令
windows下使用redis,Redis入门使用,Redis基础命令 >>>>>>>>>>>>>>>> ...
- spring boot集成redis基础入门
redis 支持持久化数据,不仅支持key-value类型的数据,还拥有list,set,zset,hash等数据结构的存储. 可以进行master-slave模式的数据备份 更多redis相关文档请 ...
- Linux基础知识入门
[Linux基础]Linux基础知识入门及常见命令. 前言:最近刚安装了Linux系统, 所以学了一些最基本的操作, 在这里把自己总结的笔记记录在这里. 1,V8:192.168.40.10V1: ...
- Redis详解入门篇
Redis详解入门篇 [本教程目录] 1.redis是什么2.redis的作者3.谁在使用redis4.学会安装redis5.学会启动redis6.使用redis客户端7.redis数据结构 – 简介 ...
- 零基础快速入门SpringBoot2.0教程 (三)
一.SpringBoot Starter讲解 简介:介绍什么是SpringBoot Starter和主要作用 1.官网地址:https://docs.spring.io/spring-boot/doc ...
- REDIS基础笔记
Redis基础笔记 资源链接 简介 简介 安装 五种数据类型及相应命令 1. 字符串类型 2. 散列类型 3. 列表类型 4. 集合类型 5. 有序集合 其他 事务 SORT 生存时间 任务队列 发布 ...
- Redis详解入门篇(转载)
Redis详解入门篇(转载) [本教程目录] 1.redis是什么2.redis的作者3.谁在使用redis4.学会安装redis5.学会启动redis6.使用redis客户端7.redis数据结构 ...
- [转帖]linux常用命令大全(linux基础命令入门到精通+实例讲解+持续更新+命令备忘录+面试复习)
linux常用命令大全(linux基础命令入门到精通+实例讲解+持续更新+命令备忘录+面试复习) https://www.cnblogs.com/caozy/p/9261224.html 总结的挺好的 ...
- 答好友困惑:Java零基础如何入门,不知道怎么学,迷茫ING
作者:程序员小跃 几个星期之前,我在知乎上看到一个提问,说是:对于完全没有经验零基础自身的数学底子也很弱学习Java应该怎么学习呢?想着类似的问题我也有过回答,并且反馈还是蛮好的,就参考之前的思路回答 ...
随机推荐
- volatile特性及内存语义
1.volatile变量自身具有下列特性:·可见性:对一个volatile变量的读,总是能看到(任意线程)对这个volatile变量最后的写入.·原子性:对任意单个volatile变量的读/写具有原子 ...
- 使用“消息服务框架”(MSF)实现分布式事务的三阶段提交协议(电商创建订单的示例)
1,示例解决方案介绍 在上一篇 <消息服务框架(MSF)应用实例之分布式事务三阶段提交协议的实现>中,我们分析了分布式事务的三阶段提交协议的原理,现在我们来看看如何使用消息服务框架(MSF ...
- 【笔记】vue-cli 打包后路径问题出错的解决方法
几天之前打包自己的vue 项目上传到远程服务器上面 但是遇到了如下几个问题: 1. 线上浏览页面时是空白页面 2. 打包后资源文件(js, css 文件)引用的路径不正确 3. 开发环境中使用到的如: ...
- Storm集群安装与部署
准备 1.三台虚拟机 192.168.1.128 Nimbus 192.168.1.131 Supervisor 192.168.1.132 Supervisor 2.JDK1.8 3.Zookeep ...
- [Gradle] 在 Eclipse 下利用 gradle 构建系统
转载自:http://www.ibm.com/developerworks/cn/opensource/os-cn-gradle/ 构建系统时候常常要用到 Ant, Maven 等工具,对于初学者 ...
- linkin大话面向对象--包和导入
我们现在的代码都扔在一个文件夹里面,比如以后我们做项目,是不是有可能有非常非常多的代码,那我就希望把不同功能和模块的类方便管理,放到不同的文件夹下,引出包概念. 什么是包,就一个文件目录,为了处理重名 ...
- alwaysOn中关于维护计划的应用方案
由于alwaysOn环境下主副本所在的实际服务器不固定, 所以我目前采取的方案是创建维护计划的时候, 在各个服务器上创建一份维护计划. (假设有2个服务器需要故障转移, 那么就在这两个服务器上分别创建 ...
- 【SqlServer系列】浅谈SQL Server事务与锁(上篇)
一 概述 在数据库方面,对于非DBA的程序员来说,事务与锁是一大难点,针对该难点,本篇文章视图采用图文的方式来与大家一起探讨. “浅谈SQL Server 事务与锁”这个专题共分两篇,上篇主讲事务及 ...
- 将centos_yum源更换为阿里云(官方文档)
http://mirrors.aliyun.com/help/centos?spm=5176.bbsr150321.0.0.d6ykiD 1.备份 mv /etc/yum.repos.d/CentOS ...
- css变量的用法——(--cssName)
CSS变量,又称——CSS自定义属性,现在很多CSS预处理/后处理程序已作了相关快捷的编译处理, 基本用法有哪些呢,我们先看一个简单的栗子:——要求,创建一个五个块元素居中的分栏样式,奇数和偶数同高不 ...