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 生存时间 任务队列 发布 ...
随机推荐
- 作业1:java虚拟机内存模型图示
看了很多篇文章,整理成一幅图,但仍然有许多不解的地方,以后再接着完善,哪位大神看到不正确的地方,请指出,谢谢.
- javaIO——CharArrayReader & CharArrayWriter
上一篇学习了StringReader和StringWriter,CharArrayReader和CharArrayWriter的实现跟他们很像,拥有的方法也基本一样.区别只是,后者两个的数据操作目标是 ...
- UML中的类图
模型 类 接口 关系 关联关系 描述了类的结构之间的关系.具有方向.名字.角色和多重性等信息.一般的关联关系语义较弱.也有两种语义较强,分别是聚合与组合 聚合 特殊关联关系,指明一个聚集(整体)和组成 ...
- Unexpected token '...'. Expected a property name.
原因:浏览器不支持 es6 扩展运算符 结论: 1.不用 ... 2. babel-polyfill对扩展运算符...搞的不是太好,要单独安装一个 plugin-proposal-object-re ...
- 使用JPA完成增删改查操作
基础的增删改查操作如下: package cn.itheima.test; import cn.itcast.domain.Customer; import cn.itcast.utils.JpaUt ...
- 微信小程序文章收录
基础篇 03-04 微信登入小程序与后端实现 - 小猿取经 - 博客园 我做的小程序 - 小y - 博客园 小程序二维码和小程序带参数二维码生成 - Likwo - 博客园 accesstoken 微 ...
- PXC集群信息查询
目录 PXC集群信息查询 pxc流量控制 PXC节点状态 PXC集群状态 节点与集群的相关信息 PXC集群事务相关信息 PXC集群信息查询 show status like "%wsrep% ...
- VLC 可能的 XML parser error 解决
由于 VLC 设置不当 (通常是动了 skin 选项……),再次加载时 VLC 不能正常启动,并报如下错误: [00007f7dd003b670] xml xml reader error: XML ...
- vmware 虚拟配置固定IP就无法联网 centos
centos7虚拟机初始运行时ip是动态随机分配的 通过修改etc/sysconfig/network-scripts/ifcfg-ens33文件的配置可以设置固定的ipTYPE=EthernetPR ...
- solr schema.xml配置
solr使用_version_来做文档的版本控制和修改时加锁(乐观锁) <field name="_version_" type="long" index ...