Redis学习笔记(一)— 基本命令和数据类型
MacOs环境
Redis基本命令
- 启动服务:
redis-server - 连接服务:
redis-cli-h指定主机/IP-p指定端口-a指定密码
- 关闭服务:先
shutdown保存数据并关闭服务;再quit退出服务 - 获取服务器信息
- 启动并连接服务之后,执行
info - 或直接在shell中执行
redis-cli info - 参数指定要获取的某部分信息,例如
info memory用来获取内存信息- Server:关于Redis服务器的基本信息
- Clients:客户端连接的状态和指标
- Memory:大致的内存消耗指标
- Persistence:数据持久化相关的状态和指标
- Stats:总体统计数据
- Replication:主从复制相关的状态和指标
- CPU:CPU使用情况
- Cluster:Redis Cluster的状态
- Keyspace:数据库相关的统计数据
- 启动并连接服务之后,执行
Redis数据类型
- 字符串
set设置键值对,已存在则覆盖,成功返回OKSET <key> <value>
get返回键对应的值,不存在则返回nilstrlen返回键对应的值的长度,不存在则返回0append向键的字符串值末尾追加字符串,返回新串长度setrange更新字符串值,偏移从0开始,返回新串长度setrange key 偏移值 newValue
setnx设置键值对,已存在则返回0不覆盖;成功返回1mset、mget一次性设置/获取多个键值对MSET key value [key value...]
object encoding <key>查看字符串编码方式- int
- embstr 长度小于等于44字节的字符串
- raw 长度大于44字节的字符串
- 列表
lpush左端插入rpush右端插入
-lrange <list> 0 -1获取所有list的值- 列表索引可以按照从左到右指定为
0 ~ N-1,也可以按照从右到左指定为-1 ~ -N
- 列表索引可以按照从左到右指定为
linsert <list> after v1 v2在list列表的v1元素后面插入v2lindenx <list> 3获取list中索引为3的元素(0开始)lpushx、rpushx列表存在时才将元素插入lpop、rpop左右两端删除,不存在返回nilltrim <list> index1 index2删除list中index1-index2之外的元素lset <list> index value将list索引为index的值设置为valueblpop <list> time、brpop <list> time若list中无数据,阻塞time秒,0表示持续阻塞
- 哈希
hmset <hashName> field name [field name...]设置哈希表hmget <hashName> field field...从一个哈希表中获取多个字段对应的值hget <hashName> field从一个哈希表中获取某个字段对应的值hexists <hashName> field测试一个哈希中是否存在某个字段hgetall获取一个hash的所有字段值(过大的哈希容易造成阻塞)hscan key cursor [MATCH pattern] [COUNT number]增量地迭代遍历元素cursor表示游标,迭代开始位置MATCH匹配满足制定Glob表达式的字段COUNT指定每次迭代的返回元素个数,默认是10- 返回的新游标为0时表示遍历完成
hset修改现有字段的值或增加新的字段hdel删除一个hash中的某个字段hsetnx字段不存在时设置字段
- 集合
- 唯一、无序
sadd set member [member...]给集合添加元素sismember set member检测member是否在set中srem从集合中删除元素scard获取集合中元素数量smembers列出集合所有元素(数据量大会导致阻塞)- 集合运算
- 并集计算:
sunion、sunionstore - 交集计算:
sinter、sinterstore - 差集计算:
sdiff、sdiffstore - 不带store直接返回操作结果;反之将结果存到一个指定的键中
- 并集计算:
- 有序集合
zadd添加集合元素zrevrange获取集合排序zincrby对集合中某个元素增加权重分数zrevrank查看元素排名zscore查看元素权重zunionstore sumName 2 set1 set2 weights 1 2合并两个集合排名- 第一个2指合并的集合数目
- weights后面的数字指集合权重的倍数,set1的权重值乘1,set2的权重值乘2
- HyperLogLog
pfadd增加数量pfmerge合并pfcount计算非重复总量
- Geo
geoadd增加经纬度坐标geopos获取指定成员坐标georadius获取指定范围内的坐标,中心点由输入的经纬度指定georadiusbymember获取指定范围内的坐标,中心点由Geo集合中的成员指定geodist比较两个坐标点的距离
Redis键管理
dbsize获取Redis中键的个数keys *、scan number获取Redis中的所有键del、unlink删除Redis中的键exists判断一个键是否存在type获取一个键的数据类型rename重命名一个键- 最佳实践:如果目标键已存在,则先unlink再重命名
Redis学习笔记(一)— 基本命令和数据类型的更多相关文章
- Redis学习笔记(五)- 数据类型之set类型
Redis 的set是string类型的无序集合.set元素最大可以包含(2的32次方-1)个元素.set的是通过hash table实现的,所以添加,删除,查找的复杂度都是O(1).hash tab ...
- Redis学习笔记(四)-数据类型之list类型
redis的list类型其实就是一个每个子元素都是string类型的双向链表.所以[lr]push和[lr]pop命令的算法时间复杂度都是O(1).另外list会记录链表的长度.所以llen操作也是O ...
- Redis学习笔记(三)-数据类型之string类型
string是redis最基本的类型,而且string类型是二进制安全的.意思是redis的string可以包含任何数据.比如jpg图片或者序列化的对象.从内部实现来看其实string可以看作byte ...
- Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash
引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...
- Redis学习笔记(二) Redis 数据类型
Redis 支持五种数据类型:string(字符串).list(列表).hash(哈希).set(集合)和 zset(有序集合),接下来我们讲解分别讲解一下这五种类型的的使用. String(字符串) ...
- Redis学习笔记(三)Redis支持的5种数据类型的总结
继续Redis学习笔记(二)来说说剩余的三种数据类型. 三.列表类型(List) 1.介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者获得列表的一段片段.列表类型内部是 ...
- Redis学习笔记~目录
回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis学习笔记(二)-key相关命令【转载】
转自 Redis学习笔记(二)-key相关命令 - 点解 - 博客园http://www.cnblogs.com/leny/p/5638764.html Redis支持的各种数据类型包括string, ...
- Redis学习笔记(1)——Redis简介
一.Redis是什么? Remote Dictionary Server(Redis) 是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value ...
随机推荐
- Lightning Web Components 开发指南(二)
Lightning Web Components 是自定义元素使用html 以及现代javascript进行构建. Lightning Web Components UI 框架使用web compon ...
- linux patch 简单学习
使用patch 我们可以方便的进行软件补丁包处理,以下演示一个简单的c 项目补丁处理 原代码 app.c #include <stdio.h> int main(){ printf(&qu ...
- 50、Spark Streaming实时wordcount程序开发
一.java版本 package cn.spark.study.streaming; import java.util.Arrays; import org.apache.spark.SparkCon ...
- 原创:自定义spark GraphX中的collectNeighborIds方法
/** * 自定义收集VertexId的neighborIds * @author TongXueQiang */def collectNeighborIds[T,U](edgeDirection:E ...
- 缺陷的优先程度(Priority)
测试人员希望程序员什么时间哪个版本修改该bug (1)Urgent 立即修改否则影响开发进度 (2)Veryhigh 本版本修改 (3)High 下个版本修改 (4)Medium 发布前修改 (5)L ...
- centos6 启动docker报错
1.启动docker报错: # service docker stop Stopping docker: [ OK ] [root@RSING data2]# service docker start ...
- vim配置无插件
其实,vim插件会影响编辑器的启动速度,虽然有些插件影响不大,我依然觉得不够,其实通过简易的状态栏,可以显示必要的信息,能自定义颜色和背景甚至透明就足够了. 一.自定义状态栏其实以下内容可以写在一行上 ...
- conda中重要的三个概念:环境、通道和包
基本使用conda必须要了解的三个概念:虚拟环境.通道和包. conda提供了在python环境下重要的编程环境管理功能,包括环境隔离和依赖包管理. 环境隔离通过虚拟环境实现,与此相关的命令有: co ...
- ldap和phpldapadmin的安装部署
LDAP 安装 一.安装LDAP 1. 安装包 yum install openssl-devel gcc libtool-ltdl-devel -y yum install openldap-ser ...
- 第10组 Beta冲刺(4/5)
链接部分 队名:女生都队 组长博客: 博客链接 作业博客:博客链接 小组内容 恩泽(组长) 过去两天完成了哪些任务 描述 将数据分析以可视化形式展示出来 新增数据分析展示等功能API 服务器后端部署, ...