redis入门:介绍、特点、安装、各类型常用操作
一、redis介绍##
Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。
Redis支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) , bitmaps(一串连续的2进制数字), hyperloglogs (一个概率统计的数据结构,可以被用来估计一个集合的基数)和 地理空间(geospatial) 索引半径查询。
Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。
二、redis特点##
通过上面的介绍可以看到,Redis有以下特点:
1、支持丰富的数据结构和命令
2、支持数据持久化(硬盘上)
3、支持事务
4、值最大可到512M
5、支持集群部署(3.0开始自带)
三、ubuntu下安装##
由于 redis 主要用来作服务器上的缓存和消息队列,主要也是针对linux系统开发的,所以这里也只介绍如何在linux系统(本文用的是ubuntu环境)下安装(windows系统上也是可以安装的,可自行google)
# apt-get install redis-server
安装完成后,redis会自动启动,我们可以通过下面的命令查看:
# ps -aux grep redis
root 2846 0.0 0.0 11740 936 pts/0 S+ 00:59 0:00 grep --color=auto redis
redis 17170 0.0 0.3 39844 7184 ? Ssl Jun12 15:31 /usr/bin/redis-server 127.0.0.1:6379
还可以通过netstat查看6379(redis默认端口)端口监听情况:
# netstat -nlt grep 6379
tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN
通过以上命令我们可以看到redis已经正确实装并启用了。
安装了redis服务端后,会自带安装一个命令行客户端程序 redis-cli,直接输入 redis-cli就可以启动:
# redis-cli
127.0.0.1:6379>
以下内容中的代码部分就可以在这里验证。
四、各类型常用操作##
1、String类型常用操作
Strings 数据结构是简单的key-value类型,value其实不仅是String,也可以是数字,常用的命令有:
- set:新增或修改记录
- get:查看获取(打印)记录
- decr:原子递减(此时value为数字)
- incr:原子递增(此时value为数字)
- mset:批量写入
- mget:批量读取
部分命令演示:
# redis-cli
//新增记录
127.0.0.1:6379> set name imooc
OK
//读取记录
127.0.0.1:6379> get name
"imooc"
//修改记录
127.0.0.1:6379> set name imooc2
OK
127.0.0.1:6379> get name
"imooc2"
//value也可以是数字
127.0.0.1:6379> set age 20
OK
127.0.0.1:6379> get age
"20"
//原子递减
127.0.0.1:6379> decr age
(integer) 19
//原子递增
127.0.0.1:6379> incr age
(integer) 20
//批量新增
127.0.0.1:6379> mset sex man city wuhan
OK
//批量读取
127.0.0.1:6379> mget sex city
1) "man"
2) "wuhan"
2、hash类型常用操作
Redis的Hash实际是内部存储的Value为一个HashMap,并提供了直接存取这个Map成员的接口,常用的命令有:
- hset key field value:将哈希表 key 中的字段 field 的值设为 value
- hget key field:获取存储在哈希表中指定字段的值
- hdel key field2 [field2]:删除一个或多个哈希表字段
- hkeys key:获取所有哈希表中的字段
- hvals key:获取哈希表中所有值
- hexists key field:查看哈希表 key 中,指定的字段是否存在
- hgetall key:获取在哈希表中指定 key 的所有字段和值
- hlen key:获取哈希表中字段的数量
- hmset key field1 value1 [field2 value2 ]:同时将多个 field-value (域-值)对设置到哈希表 key 中
- hmget key field1 [field2]:获取所有给定字段的值
部分命令演示:
//新增HASH
127.0.0.1:6379> hset user1 name atwal
(integer) 0
//获取HASH值
127.0.0.1:6379> hget user1 name
"atwal"
//增加HASH值
127.0.0.1:6379> hset user1 city wuhan
(integer) 1
//批量增加HASH值
127.0.0.1:6379> hmset user1 work coder language php
OK
//获取所有HASH字段和值
127.0.0.1:6379> hgetall user1
1) "name"
2) "atwal"
3) "city"
4) "wuhan"
5) "work"
6) "coder"
7) "language"
8) "php"
//删除某个字段
127.0.0.1:6379> hdel user1 language
(integer) 1
127.0.0.1:6379> hgetall user1
1) "name"
2) "atwal"
3) "city"
4) "wuhan"
5) "work"
6) "coder"
3、list类型常用操作
Redis list的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,常用命令:
- lpop key:移出并获取列表的第一个元素
- lpush key value1 [value2]:将一个或多个值插入到列表头部
- lpushx key value:将值value插入到列表key的表头,当且仅当key存在并且是一个列表
- rpop key:移除并获取列表最后一个元素
- rpush key value1 [value2]:在列表中添加一个或多个值
- rpushx key value:为已存在的列表添加值
- lrange key start stop:获取列表指定范围内的元素,lrange key 0 -1 表示输出所有元素
- lrem key count value:根据参数count的值(count > 0:从表头向表尾搜索,数量为count,count < 0从表尾向表头搜索,数量为count的绝对值,count = 0 移除表中所有与value相等的值),移除列表中与参数value相等的元素
- lset key index value:通过索引设置列表元素的值
- lindex key index:通过索引获取列表中的元素
- llen key:获取列表长度
部分命令演示:
//加个多个元素到列表msg
127.0.0.1:6379> lpush msg m i d e h k
(integer) 6
//向列表头部添加a元素
127.0.0.1:6379> lpushx msg a
(integer) 7
//输出列表
127.0.0.1:6379> lrange msg 0 -1
1) "a"
2) "k"
3) "h"
4) "e"
5) "d"
6) "i"
7) "m"
//移除列表第一个元素
127.0.0.1:6379> lpop msg
"a"
127.0.0.1:6379> lrange msg 0 -1
1) "k"
2) "h"
3) "e"
4) "d"
5) "i"
6) "m"
//移除列表最后一个元素
127.0.0.1:6379> rpop msg
"m"
//向列表尾部添加rm元素
127.0.0.1:6379> rpush msg rm
(integer) 6
127.0.0.1:6379> lrange msg 0 -1
1) "k"
2) "h"
3) "e"
4) "d"
5) "i"
6) "rm"
//删除值为d的元素
127.0.0.1:6379> lrem msg 0 d
(integer) 1
127.0.0.1:6379> lrange msg 0 -1
1) "k"
2) "h"
3) "e"
4) "i"
5) "rm"
//修改第二个元素为hello
127.0.0.1:6379> lset msg 1 hello
OK
127.0.0.1:6379> lrange msg 0 -1
1) "k"
2) "hello"
3) "e"
4) "i"
5) "rm"
//获取第二个位置元素值
127.0.0.1:6379> lindex msg 1
"hello"
//获取列表元素个数
127.0.0.1:6379> llen msg
(integer) 5
4、set类型常用操作
Set是string类型的无序集合。集合成员是唯一的。常用命令:
- sadd key member1 [member2]:向集合添加一个或多个成员
- sdiff key1 [key2]:返回给定所有集合的差集
- sdiffstore destination key1 [key2]:返回给定所有集合的差集并存储在 destination 中
- sinter key1 [key2]:返回给定所有集合的交集
- sinterstore destination key1 [key2]:返回给定所有集合的交集并存储在 destination 中
- sunion key1 [key2]:返回所有给定集合的并集
- sunionstore destination key1 [key2]:所有给定集合的并集存储在 destination 集合中
- smove source destination member:将 member 元素从 source 集合移动到 destination 集合
- spop key:移除并返回集合中的一个随机元素
- srandmember key [count]:返回集合中一个或多个随机数
- srem key member1 [member2]:移除集合中一个或多个成员
- smembers key:返回集合中的所有成员
- sismember key member:判断 member 元素是否是集合 key 的成员
- scard key:获取集合的成员数
部分命令演示:
//添加a b c d到follow集合中
127.0.0.1:6379> sadd follow a b c d
(integer) 4
//添加c d e f到fans集合中
127.0.0.1:6379> sadd fans c d e f
(integer) 4
//计算follow集合与fans集合的差集
127.0.0.1:6379> sdiff follow fans
1) "a"
2) "b"
//计算follow集合与fans集合的交集
127.0.0.1:6379> sinter follow fans
1) "d"
2) "c"
//计算follow集合与fans集合的并集
127.0.0.1:6379> sunion follow fans
1) "f"
2) "d"
3) "b"
4) "a"
5) "e"
6) "c"
//从follow集合中随机删除一个元素
127.0.0.1:6379> spop follow
"a"
//从follow集合中随机删除一个元素
127.0.0.1:6379> spop follow
"b"
//follow集合的所有元素
127.0.0.1:6379> smembers follow
1) "d"
2) "c"
//fans集合的所有元素
127.0.0.1:6379> smembers fans
1) "e"
2) "f"
3) "d"
4) "c"
5、Sorted Set类型常用操作
Sorted Set和Set一样也是string类型元素的集合,且不允许重复的成员。不同的是Sorted Set每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。常用命令:
- zadd key score1 member1 [score2 member2]:向有序集合添加一个或多个成员,或者更新已存在成员的分数
- zcard key:获取有序集合的成员数
- zcount key min max:计算在有序集合中指定区间分数的成员数
- zrange key start stop [withscores]:通过索引区间返回有序集合成指定区间内的成员
- zremrange key start stop [withscores]:返回有序集中指定区间内的成员,通过索引,分数从高到底
- zrangebyscore key min max [withscores] [limit]:通过分数返回有序集合指定区间内的成员
- zremrangebyscore key min max:移除有序集合中给定的分数区间的所有成员
- zrank key member:返回有序集合中指定成员的索引
- zrevrank key member:返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
- zrem key member [member ...]:移除有序集合中的一个或多个成员
- zremrangebyrank key start stop:移除有序集合中给定的排名区间的所有成员
- zrevrangebyscore key max min [withscores]:返回有序集中指定分数区间内的成员,分数从高到低排序
- zscore key member:返回有序集中,成员的分数值
部分命令演示:
//创建有序列表score
127.0.0.1:6379> zadd score 90 jim 95 lily
(integer) 2
//获取成员数
127.0.0.1:6379> zcard score
(integer) 2
//获取 0 到 100 分之间的元素个数
127.0.0.1:6379> zcount score 0 100
(integer) 2
//获取lily索引
127.0.0.1:6379> zrank score lily
(integer) 1
//获取jim分数
127.0.0.1:6379> zscore score jim
"90"
//获取索引0 1之间的带分数元素
127.0.0.1:6379> zrange score 0 1 withscores
1) "jim"
2) "90"
3) "lily"
4) "95"
6、Pub/Sub类型常用操作
Pub/Sub(发布/订阅)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息,可用于实时消息系统。常用命令:
- subscribe channel [channel ...]:订阅给定的一个或多个频道的信息。
- unsubscribe [channel [channel ...]]:指退订给定的频道。
- publish channel message:将信息发送到指定的频道。
- pubsub subcommand [argument [argument ...]]:查看订阅与发布系统状态。
命令演示:
//先在终端1上订阅频道im
127.0.0.1:6379> subscribe im
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "im"
3) (integer) 1
//在终端2上im频道上发布消息
# redis-cli
127.0.0.1:6379> publish im hello
(integer) 1
127.0.0.1:6379> publish im hi
(integer) 1
//终端1上显示收到的消息
1) "message"
2) "im"
3) "hello"
1) "message"
2) "im"
3) "hi"
7、Transactions事务
Transactions可以一次执行多个命令, 并且带有以下两个重要的保证:
- 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
- 事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。
一个事务从开始到执行会经历以下三个阶段:
- 开始事务。
- 命令入队。
- 执行事务。
常用命令:
- multi:标记一个事务块的开始。
- exec:执行所有事务块内的命令。
- discard:取消事务,放弃执行事务块内的所有命令。
- watch key [key ...]:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
- unwatch:取消 WATCH 命令对所有 key 的监视。
命令演示:
//开始一个事务
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set name imooc
QUEUED
127.0.0.1:6379> set age 20
QUEUED
127.0.0.1:6379> incr age
QUEUED
127.0.0.1:6379> incr age
QUEUED
127.0.0.1:6379> hmset user1 name atwal city wuhan
QUEUED
//执行上面事务块内的所有命令
127.0.0.1:6379> exec
1) OK
2) OK
3) (integer) 21
4) (integer) 22
5) OK
以上只是redis的基本用法,redis还有很多高级用法,如数据的备份恢复,安全,在PHP中使用等等,这些内容留在下次再分享吧:)
转自:http://www.imooc.com/article/10913
redis入门:介绍、特点、安装、各类型常用操作的更多相关文章
- Python 基于python操纵redis入门介绍
基于python操纵redis入门介绍 by:授客 QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...
- Redis(二):Redis入门介绍
Redis入门介绍目录导航: 入门概述 VMWare + VMTools千里之行始于足下 Redis的安装 Redis启动后杂项基础知识讲解 入门概述 是什么 Redis:REmote DIction ...
- Linux系统Vi/Vim编辑器的简单介绍、安装/卸载、常用命令
Linux系统Vi/Vim编辑器的简单介绍.安装/卸载.常用命令 1.介绍 vi(Visual Interface)编辑器是Linux和Unix上最基本的文本编辑器,工作在字符模式下.由于不需要图形界 ...
- redis(一) 安装以及基本数据类型操作
redis(一) 安装以及基本数据类型操作 redis安装和使用 redis安装 wget http://download.redis.io/redis-stable.tar.gz tar zxvf ...
- Redis入门很简单之六【Jedis常见操作】
Redis入门很简单之六[Jedis常见操作] http://www.tuicool.com/articles/vaqABb http://www.cnblogs.com/stephen-liu74/ ...
- redis学习笔记01 — 基本介绍、安装配置及常用命令
redis--NoSQL的一种 为了解决高并发.高可用.高扩展.大数据存储等一系列问题而产生的数据库解决方案,就是NoSQL NoSQL,非关系型数据库,全名:Not Only Sql,它不能代替关系 ...
- Docker安装Redis并介绍漂亮的可视化客户端进行操作
1 简介 Redis是使用ANSI C语言开发的基于Key-Value的高性能NoSQL数据库,在解决高并发.高可用等一系列问题中,它扮演着重要的角色.它的优势主要有: 速度快. 持久化. 原子性. ...
- NoSQL数据库之Redis数据库:Redis的介绍与安装部署
NoSQL(NoSQL = Not Only SQL),它指的是非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的w ...
- redis学习(一) redis的介绍与安装
redis简单介绍 redis全称remote-dictionary-server 直译为远程字典服务器, 是一个高性能的key-value存储系统,也被称为数据结构服务器,因为其所存储的数据值(va ...
随机推荐
- 深度优先搜索(dfs),城堡问题
题目链接:http://poj.org/problem?id=1164 1.深搜,每个点都访问一次,没有标记的话,就做深搜,同时标记. #include <iostream> #inclu ...
- CF633C Spy Syndrome 2
嘟嘟嘟 题面:把一句话加密:1.所有字母变成小写.2.翻转所有单词.3.去掉空格.然后给你一句加密后的字符串以及一些出现在原句和没有出现在原句的单词,让你还原原句.注意,每一个单词可以使用多次,如果有 ...
- ACM/ICPC 2018亚洲区预选赛北京赛站网络赛 A、Saving Tang Monk II 【状态搜索】
任意门:http://hihocoder.com/problemset/problem/1828 Saving Tang Monk II 时间限制:1000ms 单点时限:1000ms 内存限制:25 ...
- 2017.9.1 Java中的程序方法
今日内容介绍 1.方法基础知识 2.方法高级内容 3.方法案例 01方法的概述 * A: 为什么要有方法 * 提高代码的复用性 * B: 什么是方法 * 完成特定功能的代码块. 02方法的定义格式 * ...
- mac 上安装lua
mac 安装lua google了好个看起来都不怎么好操作,这个是在命令行下操作的很简单. http://www.lua.org/download.html curl -R -O http://www ...
- lucene&solr学习——索引维护
1.索引库的维护 索引库删除 (1) 全删除 第一步:先对文档进行分析 public IndexWriter getIndexWriter() throws Exception { // 第一步:创建 ...
- toad for sql server
数据库连接工具 toad for sql sever
- iOS | AFNetworking封装
为大家分享一个IOS处理网络请求,网络上传,网络下载等功能全面的一个第三方框架-AFNetworking,这是一个使用非常方便的网络框架. 最新的版本是基于NSURLSession,原来的NSURLC ...
- react.js中实现tab吸顶效果问题
在react项目开发中有一个需求是,页面滚动到tab所在位置时,tab要固定在顶部. 实现的思路其实很简单,就是判断当滚动距离scrollTop大于tab距离页面顶部距离offsetTop时,将tab ...
- C++ push方法与push_back方法
[转载他人的文章,下午在搞c++,谢谢共享] [摘要] push与push_back是STL中常见的方法,都是向数据结构中添加元素.初识STL,对于添加元素的方法以产生混淆,这里暂对两种方法作出比较分 ...