常用命令

redis-server启动redis

redis-server /opt/redis/redis.conf    配置启动
redis-server --port 6379 --dir /usr/local/data(存放持久化文件和日志文件的目录)   按照参数启动其他配置默认

redis-cli命令行客户端

redis-cli -v  查看redis的版本信息
redis-cli -h {host} -p {port}   交互式方式连接
redis-cli -h {host} -p {port} {command}  命令方式连接
redis-cli shutdown optional{nosave|save}  停止redis服务 是否生成持久化文件
命令:发送命令(网络时间)  执行命令(redis命令时间)  返回结果(网络时间)
keys *  所有键  遍历所有键 大量键下禁止使用
dbsize  键总数 直接获取内置的键总数变量
exists key 键是否存在
del key...    删除键
expire key seconds  键过期
ttl key  键的剩余过期时间  -1没设置过过期时间  -2键不存在
type key 键的数据类型  不存在->none
object encoding key 查看内部编码类型

String

set key value [ex second] [px millisecond] [nx(键必须不存在)|xx(必须存在)]
setex key seconds value
setnx key value
get key
mset k1 v1 k2 v2
mget k1 k2 k3

Hash

hset key field value
hsetnx key field value
hget key field
hdel key field ...
hlen key
hmget key f1 f2
hmset key f1 v1 f2 v2
hexists key field
hkeys key  获取所有的field
hvals key  获取所有的值
hgetall key 获取所有的field和值

List(索引下标有序,时间轴,消息队列)

rpush|lpush key v1 v2
lrange key start end
linsert key before|after pivot value 在pivot前后插入value
lindex key index
llen key
lpop|rpop key  左|右侧弹出元素(删除)
lrem key count value   删除指定元素  count  >0从左向右删除最多count个value元素  =0删除所有
ltrim key start end  相当于substring的用法
lset key index newValue
blpop|brpop key1 key2 ... timeout 阻塞命令

Set(标签,社交)

sadd key element1 element2 ...
srem key e1 e2 ...
scard key  计算元素个数
sismember key v 判断元素是否在集合中
srandmember key count 随机从集合中返回指定个数元素
spop key 随机弹出一个元素(删除)
smembers key 获取所有元素
sinter k1 k2  多个集合的交集
suinon k1 k2 多个集合的并集
sdiff k1 k2 多个集合的差集
sinterstore destination k1 k2  将k1 k2交集保存到destination中
sunionstore destination k1 k2 
sdiffstore destination k1 k2

SortSet(分值有序,排行榜,社交)

zdd key score member [score member ...] 
zcard key
zscore key member
zrank key member  计算成员到排名位置
zrevrank key member
zrem key m1 m2 ..
zincrby key value member 给member的score增加value分
zrange key start end [withscores] 从高到低返回
zrevrange key start end
zrangebyscore key min max [withscores] [limit offset count] 从指定范围返回
zcount key min max
zremrangebyrank key start end   删除指定排名内到升序元素
zremrangebyscore key min max
zinterstore destination numkeys key .... [weights weight...] [aggregate sum|min|max]
destination:交集计算结果保存到这个键
numkeys:需要做交集计算键到个数
weights:每个键到权重,在做交集计算时,每个键中到每个member 会将自己到分数乘以这个权重值
aggregate:计算成员交集后,分值按照sum|min|max做汇总,默认sum
zunionstore destination numkeys key ... [weights weight ...] [aggreate sum|min|max]

慢查询

config set sowlog-log-lower-than 20000    超过20秒记录
config set slowlog-max-len 1000   日志队列记录最长1000
config rewrite  配置持久化到本地配置文件
slowlog get [n]  获取n条日志记录
slowlog len  日志队列长度
slowlog reset  清空慢查询日志

事务

watch 事务期间监控某个值不变才能正确提交
multi  开始
exec  提交  
LUA脚本

redis-benchmark  redis基准测试工具

redis-benchmark -c 100 -n 20000  -t get,set -q --csv  100个客户端同时向redis发送get,set请求,共执行20000次。-q只输出每秒响应请求数据量并导出到csv

持久化RDB(紧凑压缩的二进制文件)

手动触发 :1.save(阻塞当前redis服务器)  2.bgsave(执行fork操作创建子进程)
自动触发:1.使用save m n配置 2.执行全量复制 3.执行debug reload 4.执行shutdown

持久化AOF(append only file)以独立日志的方式记录每次写命令

append, sync, rewrite, load
命令写入-> append-> AOF缓存-> sync-> AOP文件rewrite<- 重启load
redis-check-aof --fix 修复损坏的aof文件   diff -u 比较文件不同  
redis-check-dump 持久化文件检测和修复工具

redis-sentinel 启动redis-sentinel

配置文件中的  sentinel monitor mymaster 127.0.0.1 6379 2   代表sentinel节点需要监控mymaster这个主节点,2代表判断主节点失败至少需要2个sentinel节点同意
redis-sentinel /opt/redis/redis-sentinel-26379.conf 
 
 
 

Redis开发与运维的更多相关文章

  1. Redis开发与运维:SDS

    STRING 我们会经常打交道的string类型,在redis中拥有广泛的使用.也是开启redis数据类型的基础. 在我最最开始接触的redis的时候,总是以为字符串类型就是值的类型是字符串. 比如: ...

  2. Redis开发与运维学习笔记

    <Redis开发与运维>读书笔记   一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争 ...

  3. Redis实战(七)Redis开发与运维

    Redis用途 1.缓存 Redis提供了键值过期时间设置, 并且也提供了灵活控制最大内存和内存溢出后的淘汰策略. 可以这么说, 一个合理的缓存设计能够为一个网站的稳定保驾护航. 2.排行榜系统 Re ...

  4. Redis 开发与运维

    Getting Start 高性能 性能优势的体现 C语言实现的内存管理 epoll的I/O多路复用技术+IO连接/关闭/读写通过事件实现异步的非阻塞IO TCP协议 单线程架构,不会因为高并发对服务 ...

  5. 《Redis开发与运维》快速笔记(一)

    1.前言&基本介绍 在原始的系统架构中,我们都由程序直接连接DB,随着业务的进一步开展,DB的压力越来越大,为了缓解DB的这一压力,我们引入了缓存,在程序连接DB中加入缓存层, 从而减轻数据库 ...

  6. 《Redis开发与运维》

    第1章 初识Redis 1. Redis介绍: Redis是一种基于键值对(key-value)的NoSQL数据库. 与很多键值对数据库不同的是,Redis中的值可以是由string(字符串).has ...

  7. 《Redis开发与运维》读书笔记

    一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争问题 基于键值对的数据结构,支持的数据结构丰富.它 ...

  8. redis 开发与运维 学习心得1

    主要是命令相关 第一章 初识Redis 1.redis是基于键值对的NoSQL. 2.redis的值可以是 string, hash, list, set, zset, bitmaps, hyperl ...

  9. Redis开发与运维:linux安装

    Linux 安装 我的系统是inux 系统,官网下载 https://redis.io/download redis-5.0.5.tar.gz 解压: 编译安装: 官网和文档说得已经很清楚了,现在就执 ...

随机推荐

  1. hibernate之查询

    Query对象 方便的对数据库和持久化对象进行查询,两种表达方式:HQL和SQL; Query经常用来绑定查询参数,限制查询条数.并最终执行查询语句. HQL 查询一个简单类(查询所有) @Test ...

  2. 万物云平台数据转发 c# 控制台程序

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...

  3. JSP动作元素<jsp:include>和<jsp:param>的搭配使用

    最近开发项目中广告头的优化:引入了<jsp:include page="XX.jsp"></jsp:include> 当<jsp:include> ...

  4. spring处理线程并发

    http://www.open-open.com/bbs/view/1320130410702

  5. python3使用ip地址代理

    第一种IP地址代理方式from urllib import request if __name__ == "__main__": # 访问网址 url = 'http://www. ...

  6. unigui回车代替TAB

    unigui回车代替TAB 在业务系统中常常使用回车键(Enter)替代Tab键完成焦点跳转,在uniGUI下,可以不用代码,直接使用TUniForm的NavigateKeys进行设置: 其中Next ...

  7. FastReport二维码打印存在的问题

    FastReport二维码打印存在的问题 (2018-05-21 09:28:38) 转载▼ 标签: delphi 分类: Delphi10.2 FastReport本身支持二维码,实际应用中遇到这样 ...

  8. phpstudy 配置 memcached / memcache

    https://blog.csdn.net/zql898626913/article/details/77309269

  9. FastReport报表设计(仔细看)

    FastReport报表设计 2011-06-16 16:56:19|  分类: 系统开发|举报|字号 订阅     下载LOFTER我的照片书  |     目录 5.1 前言 5.2 基本概念及操 ...

  10. JS学习笔记4_BOM

    1.frame相关对象 top:指向最外层框架,使用top可以在一个框架中访问另一个框架,例如top.frames[index/name] parent:指向当前框架的直接上层框架 window:代码 ...