redis基础操作概念等笔记
Redis常用配置
- daemonize -》是否是后台进程
- port -》对外端口
- logfile -》Redis 系统日志
- dir -》Redis 工作目录
Redis的链接
redis-cli -h 127.0.0.1 -p 6379
测试链接
使用ping返回PONG
查看配置
通过config get *命令可以查看
通过配置文件方式启动
找到redis所在的目录以下是mac系统的
cd /usr/local/etc
复制一份新的配置文件
cat redis.conf| grep -v "#" |grep -v "^$" >redis-6382.log
配置文件内容如下
daemonize yes #是否后台启动
port 6382 #启动端口修改为6382
dir /usr/local/var/db/redis/ #文件的位置,比如log
logfile "6382.log" #log文件的名字
启动
redis-server redis-6382.conf
查看进程
ps -ef |grep redis-server |grep 6382
通用命令
keys:遍历出所有的key,O(n)时间复杂度,生产环境不建议多用,可以在从节点用。
dbsize:计算key的总数,可以线上用,redis自带的计数器时间复杂度O(1)
exists key:检查key是否存在,时间复杂度O(1)
del key:删除key-value,时间复杂度O(1)
expire key seconds:keys在seconds秒后过期,时间复杂度O(1)
ttl key:查看key剩余的过期时间,-1表示存在但是没有过期时间,-2表示不存在。时间复杂度O(1)
type key:键的类型,时间复杂度O(1)
persist key:去掉key的过期时间,时间复杂度O(1)
数据类型
string,hash,list,set,sorted set
编码形式
raw,int,embstr,hashtable,ziplist,linkedlist,intest,skiplist
单线程
为什么?
纯内存
非阻塞IO(epoll)
避免线程切换和资源竞争
需要注意的:
1.一次只执行一条命令
2.拒绝长命令,比如keys *
字符串
结构和命令
结构
key hello value world
key counter value 1
key bit valuee 1010101010
key j value json结构
最大512M。
命令
get,set,del
incr key 自增1
decr 自减1
incrby key k,自增k
decrby key k 自减k
场景
- 缓存
- 计数器
- 分布式锁
计数器
incr userid:pageview
缓存
比如访问1.mp4,首先访问redis如果没有再访问mysql,mysql查到先反给redis,然后返回给客户。redis充当缓存的功能。
分布式id生成器
set setnx setxx
set key value #设置key O(1)
setnx key value #key不存在才设置 类似insert O(1)
setxx key value #key存在才设置 类似update O(1)
mset key1 key2 key3 O(n)
mget key1 key2 key3 #节省了网络时间,批量查询,如果量大可以拆分。O(n)
getset key value,设置新值返回老值 O(1)
append key value 增加 O(1)
strlen key 返回字符串的长度 O(1)
incybyfloat key 3.5 #增加key对应之3.5
getrange key start end #类似切片
setrange key start end
hash
key {field:value}
命令
hget key field O(1)
hset key field O(1)
hdel key field O(1)
hexists key field O(1)
hlen key field O(1)
hmget key field1 file2
hmset key field1 file2
记录网站每个用户个人网页的访问量
hincrby user:1:info pageiew count
其他命令
hgetall key O(n)
hvals key O(n)
hkeys key O(n)
列表
TimeLine
更新使用Lpush
Lrange 获取数据
其他
blpop,lpop的阻塞版本,timeout是阻塞超时
组合使用
LPUSH +LPOP =stack
LPUSH +RPOP =Queue
LPUSH +LTRIM =列表大小有限制
LPUSH +BRPOP =Message Queue
集合
sadd 添加
scrad
sismenember
srandmemeber
spop 集合弹出
smembers
实战
添加标签,共同关注
其他操作
sdiff sinter sunion
场景应用
SADD 标签
SPOP/SRANDMEMBER 随机数的场景
SADD+SINTER 共同好友等功能
有序集合
zadd key socre element #添加元素
zscore key element
zcrad key #返回元素的个数
zrank
zrem
zrange 0 -1 #返回指定索引范围内的升序元素
zcount startscore endscore
实战
排行榜 根据时间戳或者阅读数之类的。
redis基础操作概念等笔记的更多相关文章
- 【转】Redis 基础操作和命令
笔记 Redis提供了六种基本的数据结构:String,Hash,List,Set,Sorted Set,HyperLogLog. Redis的特点:纯内存操作,单线程工作模型,非阻塞I/O多路复用. ...
- Redis 基础操作
[Redis 基础操作] 1.ECHO message. Returns message. 2.PHING Returns PONG if no argument is provided, other ...
- redis基础操作~~数据备份与恢复、数据安全、性能测试、客户端连接、分区
数据备份与恢复 数据备份redis save 命令用于创建当前数据库的备份. redis 127.0.0.1:6379> SAVE OK 该命令将在 redis 安装目录中创建dump.rdb文 ...
- 三、Redis基础操作
前言: Redi是key-value的NoSQL,我们用Redis提供的redis-cli就能操作String类型key和各种数据类型value.但是放入的不是特定类型数据,添加的都是一个一个Stri ...
- redis 基础操作教程
1.linux 安装redis : Linux 下安装 下载地址:http://redis.io/download,下载最新稳定版本. 本教程使用的最新文档版本为 2.8.17,下载并安装: $ wg ...
- redis基础操作
/** * redis的Java客户端Jedis测试验证 * * @author */ public class Test { /** * 非切片客户端链接 */ private Jedis jedi ...
- Java代码redis基础操作
maven依赖包: <dependency> <groupId>redis.clients</groupId> <artifactId>jedis< ...
- redis简单操作
一.redis 基础操作 1.1.string 类型及操作 string 是最简单的类型,一个key对应一个value,string类型是二进制安全的.redis的string可以包含任何数据. 1. ...
- REDIS基础笔记
Redis基础笔记 资源链接 简介 简介 安装 五种数据类型及相应命令 1. 字符串类型 2. 散列类型 3. 列表类型 4. 集合类型 5. 有序集合 其他 事务 SORT 生存时间 任务队列 发布 ...
随机推荐
- MVC授权不通过之后不执行任何自定义ActionFilter
如下一个Action [Authorize] [F1]//自定义过滤器,继承自ActionFilter public ActionResult Index() { return View(); } 如 ...
- 出现 HTTP 错误 500.19 错误代码 0x800700b7
这个内容出现主要问题是在IIS上,我们一般程序开发 iis中默认的路径只是http://localhost/,相当于环境变量中已定义好了,如果自己创建的项目直接将路径定义到这,就会替换图二中的路径,然 ...
- ef core many to many
https://stackoverflow.com/questions/46184678/fluent-api-many-to-many-in-entity-framework-core/461847 ...
- SpringBoot之Redis访问(spring-boot-starter-data-redis)
依赖注入: <!--dependency for redis--> <!-- https://mvnrepository.com/artifact/org.springframewo ...
- 利用commands模块执行shell命令
利用commands模块执行shell命令 用Python写运维脚本时,经常需要执行linux shell的命令,Python中的commands模块专门用于调用Linux shell命令,并返回状态 ...
- ConcurrentDictionary源码概读
ConcurrentDictionary的数据结构主要由Tables和Node组成,其中Tables包括桶(Node,节点)数组.局部锁(Local lock).每个锁保护的元素数量(PerLock) ...
- E - GCD HDU - 2588
The greatest common divisor GCD(a,b) of two positive integers a and b,sometimes written (a,b),is the ...
- 关于Java的Object.clone()方法与对象的深浅拷贝
文章同步更新在个人博客:关于Java的Object.clone()方法与对象的深浅拷贝 引言 在某些场景中,我们需要获取到一个对象的拷贝用于某些处理.这时候就可以用到Java中的Object.clon ...
- javascript弹出带文字信息的提示框效果
// position of the tooltip relative to the mouse in pixel // <html><head><meta charse ...
- 2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018) D. Delivery Delays (二分+最短路+DP)
题目链接:https://codeforc.es/gym/101933/problem/D 题意:地图上有 n 个位置和 m 条边,每条边连接 u.v 且有一个距离 w,一共有 k 个询问,每个询问表 ...