首页 > 数据库 >redis的客户端操作,使用场景

redis的客户端操作,使用场景

时间:2024-03-20 16:47:01浏览次数:27  
标签:场景 name 复杂度 redis value field key 客户端

####配置允许远程链接###########
# 1 使用配置文件启动redis
daemonize yes

bind 0.0.0.0
protected-mode no
requirepass 123456

pidfile /var/run/redis.pid
port 6379
dir "/root/redis-7.2.4/data"
logfile 6379.log

# 2 redis-server ./redis-conf

# 3 允许远程链接
    -方式一: win :redis-cli -h 10.0.0.111 -p 6379
    -方式二:resp 远程链接
# 4 如果连不上:关防火墙
    systemctl stop firewalld
    systemctl status firewalld


    
    
    

### 客户端连接,常用操作###
redis-cli -h 10.0.0.111 -p 6379
redis-cli -h 10.0.0.111 -p 6379 -a 123456
ping   #返回PONG,说明联通的

## 有密码的情况可以两种登陆方式
# 方式一
redis-cli -h 127.0.0.1    -p 6370 -a 123456
# 方式二
先登陆,再通过auth输入密码


#### redis配置文件

## redis-cli进入
CONFIG GET *   # 390对--》100多键值--》配置信息
    -bind
    -port
CONFIG SET maxmemory 128M  # 设置最大使用的内存
CONFIG set requirepass 654321  # 设置密码 ---》客户端可以改服务端密码
# 永久生效
CONFIG REWRITE  # 保存到配置文件


### redis 入侵到 linux操作系统
https://cloud.tencent.com/developer/article/1440296
# 避免:
    -运行redis进程的用户不要用root
    -运行redis的用户不允许登录

redis使用场景

#1  缓存系统:使用最广泛的就是缓存
#2  计数器:网站访问量,转发量,评论数(文章转发,商品销量,单线程模型,不会出现并发问题)
    django--->并发操作数据库---》数据没有错乱--》mysql是一个服务---》支持并发访问的--》处理了并发安全的问题---》不需要我们从程序端考虑并发安全问题
    redis--》没有锁--》不存在并发安全问题--》redis数据读写是单线程的
#3 消息队列:发布订阅,阻塞队列实现(简单的分布式,blpop:阻塞队列,生产者消费者)
    IPC 进程间通信
    具体到项目:遇到问题发通知
        -1w个问题,都要发通知
        -只要产生问题---》就把问题丢到消息队列中---》另一端起程序,发送消息
        
        
#4 排行榜:有序集合(阅读排行,点赞排行,推荐(销量高的,推荐))
#5 社交网络:很多特效跟社交网络匹配,粉丝数,关注数
#6  实时系统:垃圾邮件处理系统,布隆过滤器

通用命令

#### 1-keys 
#打印出所有key
keys * 
#打印出所有以he开头的key
keys he*
#打印出所有以he开头,第三个字母是h到l的范围
keys he[h-l]
#三位长度,以he开头,?表示任意一位
keys he?
#keys命令一般不在生产环境中使用,生产环境key很多,时间复杂度为o(n),用scan命令



####2-dbsize   计算key的总数
dbsize #redis内置了计数器,插入删除值该计数器会更改,所以可以在生产环境使用,时间复杂度是o(1)


###3-exists key 时间复杂度o(1)
#设置a
set a b
#查看a是否存在
exists a
(integer) 1
#存在返回1 不存在返回0


###4-del key  时间复杂度o(1)
删除成功返回1,key不存在返回0


###5-expire key seconds  时间复杂度o(1)
expire name 3 #3s 过期
ttl name  #查看name还有多长时间过期
persist name #去掉name的过期时间


###6-type key  时间复杂度o(1)
type name #查看name类型,返回string




### 7 其他

info命令:内存,cpu,主从相关


client list  正在连接的会话
client kill ip:端口 # redis-cli -a 654321 client kill 10.0.0.1:64794

dbsize  总共有多少个key
flushall  清空所有
flushdb  只清空当前库
select 数字  选择某个库  总共16个库
monitor  记录操作日志,夯住
redis-cli -a 654321 monitor

# https://gitee.com/jiangwenhui_admin/redis_admin
# https://gitee.com/jiangwenhui_admin/sql_manage

字符串类型

###1---基本使用get,set,del
get name       #时间复杂度 o(1)
set name lqz   #时间复杂度 o(1)
del name       #时间复杂度 o(1)


###2---其他使用incr,decr,incrby,decrby
# 如果值不存在,就会创建
incr age  #对age这个key的value值自增1
decr age  #对age这个key的value值自减1
incrby age 10  #对age这个key的value值增加10
decrby age 10  #对age这个key的value值减10


#统计网站访问量(单线程无竞争,天然适合做计数器)

###3---set,setnx,setxx
set name lqz  #不管key是否存在,都设置 
setnx name lqz #key不存在时才设置(新增操作)
set name lqz nx #同上
set name lqz xx #key存在,才设置(更新操作)

###4---mget mset
mget key1 key2 key3     #批量获取key1,key2.。。时间复杂度o(n)
mset key1 value1 key2 value2 key3 value3    #批量设置时间复杂度o(n)
#n次get和mget的区别
#n次get时间=n次命令时间+n次网络时间
#mget时间=1次网络时间+n次命令时间

###5---其他:getset,append,strlen
getset name lqznb #设置新值并返回旧值 时间复杂度o(1)
append name 666 #将value追加到旧的value 时间复杂度o(1)
strlen name  #计算字符串长度(注意中文)  时间复杂度o(1)

###6---其他:incrybyfloat,getrange,setrange
increbyfloat age 3.5  #为age自增3.5,传负值表示自减 时间复杂度o(1)
getrange key start end #获取字符串制定下标所有的值  时间复杂度o(1)
setrange key index value #从指定index开始设置value值  时间复杂度o(1)


# 缓存
# 计数器

hash类型

###1---hget,hset,hdel
hget key field  #获取hash key对应的field的value 时间复杂度为 o(1)
hset key field value #设置hash key对应的field的value值 时间复杂度为 o(1)
hdel key field #删除hash key对应的field的值 时间复杂度为 o(1)

#测试
hset user:1:info age 23
hget user:1:info age
hset user:1:info name lqz
hgetall user:1:info
hdel user:1:info age

###2---hexists,hlen
hexists key field  #判断hash key 是否存在field 时间复杂度为 o(1)
hlen key   #获取hash key field的数量  时间复杂度为 o(1)
hexists user:1:info name
hlen user:1:info  #返回数量
        
###3---hmget,hmset
hmget key field1 field2 ...fieldN  #批量获取hash key 的一批field对应的值  时间复杂度是o(n)
hmset key field1 value1 field2 value2  #批量设置hash key的一批field value 时间复杂度是o(n)

###4--hgetall,hvals,hkeys
hgetall key  #返回hash key 对应的所有field和value  时间复杂度是o(n)
hvals key   #返回hash key 对应的所有field的value  时间复杂度是o(n)
hkeys key   #返回hash key对应的所有field  时间复杂度是o(n)
###小心使用hgetall

##1 计算网站每个用户主页的访问量
hincrby course:1:info pageview count


##2 缓存mysql的信息,直接设置hash格式


## 其他操作
##其他操作 hsetnx,hincrby,hincrbyfloat
hsetnx key field value #设置hash key对应field的value(如果field已存在,则失败),时间复杂度o(1)
hincrby key field intCounter #hash key 对英的field的value自增intCounter 时间复杂度o(1)
hincrbyfloat key field floatCounter #hincrby 浮点数 时间复杂度o(1)

列表类型

# 1  插入操作
#rpush 从右侧插入
rpush key value1 value2 ...valueN  #时间复杂度为o(1~n)
#lpush 从左侧插入
#linsert
linsert key before|after value newValue   #从元素value的前或后插入newValue 时间复杂度o(n) ,需要遍历列表
linsert listkey before b java
linsert listkey after b php
# 2 删除操作
lpop key #从列表左侧弹出一个item 时间复杂度o(1)

rpop key #从列表右侧弹出一个item 时间复杂度o(1)

lrem key count value
#根据count值,从列表中删除所有value相同的项 时间复杂度o(n)
1 count>0 从左到右,删除最多count个value相等的项
2 count<0 从右向左,删除最多 Math.abs(count)个value相等的项
3 count=0 删除所有value相等的项
lrem listkey 0 a #删除列表中所有值a
lrem listkey -1 c #从右侧删除1个c

ltrim key start end #按照索引范围修剪列表 o(n)
ltrim listkey 1 4 #只保留下表1--4的元素


# 3 查询操作
lrange key start end #包含end获取列表指定索引范围所有item  o(n)
lrange listkey 0 2
lrange listkey 1 -1 #获取第一个位置到倒数第一个位置的元素

lindex key index #获取列表指定索引的item  o(n)
lindex listkey 0
lindex listkey -1

llen key #获取列表长度


# 4 修改操作
lset key index newValue #设置列表指定索引值为newValue o(n)
lset listkey 2 ppp #把第二个位置设为ppp
# 5 实战
实现timeLine功能,时间轴,微博关注的人,按时间轴排列,在列表中放入关注人的微博的即可



# 6 其他操作
blpop key timeout #lpop的阻塞版,timeout是阻塞超时时间,timeout=0为拥有不阻塞 o(1)
brpop key timeout #rpop的阻塞版,timeout是阻塞超时时间,timeout=0为拥有不阻塞 o(1)

#要实现栈的功能 先进后出
lpush+lpop
#实现队列功能
lpush+rpop
#固定大小的列表
lpush+ltrim

#消息队列
lpush+brpop

 

标签:场景,name,复杂度,redis,value,field,key,客户端
From: https://www.cnblogs.com/wzh366/p/18085548

相关文章

  • redis的配置启动
    centos上安装redis#Redis是什么1C语言开源,非关系型数据库:早起版本2w3千行2基于键值对的存储系统:字典形式3多种数据结构:字符串,hash,列表,集合,有序集合4高性能(并发量高),功能丰富(不仅仅做缓存,还能做别的)#那些公司在用github,twitter,stackoverflow,阿里,百度,微博,美团,搜狐......
  • 【开发环境搭建篇】Redis客户端安装和配置
    作者介绍:本人笔名姑苏老陈,从事JAVA开发工作十多年了,带过大学刚毕业的实习生,也带过技术团队。最近有个朋友的表弟,马上要大学毕业了,想从事JAVA开发工作,但不知道从何处入手。于是,产生了写一个博客专栏想法,介绍当前互联网企业JAVA项目开发如何快速入门。本文收录于《30天企......
  • redis自学(22)Redis是单线程还是多线程?
    Redis是单线程还是多线程?Redis到底是单线程还是多线程? 如果仅仅聊Redis的核心的业务处理部分(命令处理),答案是单线程 如果是聊整个Redis那么答案是对线程在Redis版本迭代过程中,在两个重要的时间节点上引入了多线程的支持:Redisv4.0:引入多线程异步处理一些耗时较长的任务,......
  • Redis中文乱码问题
    最近排查问题,发现之前的开发将日志写在redis缓存中(不建议这样做),我在查看日志的时候发现没办法阅读,详细是这样的:查阅资料后发现是进制问题,解决方法是启动客户端的时候将redis-cli改为redis-cli--raw现在查看缓存数据就变成这样的乱码了,这是由于我们写程序使用UTF-8的编......
  • [转]Garnet: 力压Redis的C#高性能分布式存储数据库
    今天看到微软研究院开源了一个新的C#项目,叫Garnet,它实现了Redis协议,可以直接将Redis替换为Garnet,客户端不需要任何修改。根据其官网的信息,简单的介绍一下它。开源仓库地址:https://github.com/microsoft/garnet文档地址:https://microsoft.github.io/garnet/Garnet是微软研究院基......
  • Redis数据库安装与使用总结
    Redis语句总结一、基本概念Redis全称:RemoteDictionaryServer(远程字典服务器)的缩写,以字典结构存储数据,并允许其他应用通过TCP协议读写字典中的内容。使用C语言编写,并以内存作为数据存储介质,所以读写数据的效率极高*redis的官方只提供了linux版本的redis,window系统的redis......
  • 为什么延迟删除可以保证MYSQL 与redis的一致性?
    看过很多保持MYSQL与redis保持一致性的文章都提到了延迟删除,其实脱离任何业务场景的设计都是不切实际的,所以我会本着一个通用的读写场景去分析为什么延迟删除大概率可以保证MYSQL与redis的最终一致。通常的读写场景通常在使用redis作为读写缓存时,我们采用的是cacheasidepatte......
  • tomcat采集阿里云slb真实客户端ip
    tomcat采集阿里云slb真实客户端ip......
  • Go Redis专题精讲
    GoRedis专题精讲一、介绍1.1、客户端列表go-redis提供各种类型的客户端:Redis单节点客户端Redis集群客户端Redis哨兵客户端Redis分片客户端Redis通用客户端go-redis也可以用于kvrocks,kvrocks是分布式键值NoSQL数据库,使用RocksDB作为存储引擎......
  • 华为云GeminiDB新版本发布:全面支持Redis 6.2
    华为云GeminiDB是一款兼容Redis协议的弹性KV(Key-Value)数据库,支持远超内存的容量和极致的性能,可支撑用户平滑迁移,在广告、游戏、电商等行业有着广泛的应用。今年3月上线的新版本,GeminiDB已全面支持Redis6.2,用户可在华为云GeminiDB产品官网购买使用。新版本的GeminiDB发布了一系......