Redis 键值对数据库学习

news2024/11/24 12:01:41

目录

一、介绍

二、安装以及连接

三、设置连接密码

四、连接报错

五、redis 操作字符串以及过期时间

六、 redis 列表操作

七、redis 集合操作

八、hash 哈希操作

九、redis 发布和订阅操作

十、RDB和AOF的两种数据持久化机制

十一、 其他机器连接redis

十二、 python 操作redis

1. 安装python-redis  以及连接redis

2. 操作数据

3.  事务操作

4. 发布与订阅


一、介绍

redis 是一种 nosql 数据库,他的数据是保存在内存中,同时 redis 可以定时把内存数据同步到磁盘,即可以将数据持久化,并且他比 memcached 支持更多的数据结构( string,list表[队列和栈],set[集合],sorted set[有序集合],hash(hash表)。

redis 使用场景:

  1. 登录会话存储,存储在 redis 中,与 memcached 相比,数据不会丢失。
  2. 排行版/计数器:比如一些秀场类的项目,经常会有一些前多少名的主播排名。还有一些文章阅读量的技术,或者新浪微博的点赞数等。
  3. 作为消息队列:比如 celery 就是使用 redis 作为中间人。
  4. 当前在线人数:还是之前的秀场例子,会显示当前系统有多少在线人数。
  5. 一些常用的数据缓存:比如我们的 BBS 论坛,板块不会经常变化的,但是每次访问首页都要从"ys591 中获取,可以在 redis 中缓存起来,不用每次请求数据库。
  6. 把前200篇文童缓存或者评论缓存:一般用户浏览网站,只会浏览前面一部分文章或者评论,那么可以把前面200篇文童和对应的评论缓存起来。用户访问超过的,就访问数据库,并且以后文章超过200篇,则把之前的文章删除。
  7. 好友关系: 微博的好友关系使用 redis 实现。
  8. 发布和订阅功能:可以用来做聊天软件。        

二、安装以及连接

参考文章链接:【Redis】在Mac上安装使用redis的教程_mac安装redis-CSDN博客

  1. 安装:brew install redis
  2. 开启服务:brew services start redis
  3. 关闭服务: brew services stop redis
  4. 指定端口号:redis-cli -h 127.0.0.1 -p 6379

-h ip地址; -p 端口号 ; -a 密码 

三、设置连接密码

  1. 配置文件设置连接密码:

第一步:cd /opt/homebrew/etc 

第二步:open redis.conf

报错了!!No application knows how to open URL file:///opt/homebrew/etc/redis.conf

解决: 换成  open -e redis.conf  命令

第三步:在redis.conf 中修改requirepass 密码,如图所示:

 第四步:运行 redis-server /opt/homebrew/etc/redis.conf 

第五步:运行 redis-cli -h 127.0.0.1 -p 6379 -a 123456

四、连接报错

报错:Could not connect to Redis at 127.0.0.1:6379: Connection refused

方式一: 查看服务是否启动

方式二: 如果服务已经启动还是报错,通过以下方式解决:

  1. 检查redis 服务的状态:redis-cli ping,确认redis 服务正在运行,如果返回PONG,则表示Redis服务器正在运行。
  2. 如果没有返回或者返回其他错误消息,我们需要通过以下命令启动Redis服务器: redis-server
  3. 参考链接: 解决Could not connect to Redis at 127.0.0.1:6379: Connection refused的具体操作步骤_mob649e816a3664的技术博客_51CTO博客

五、redis 操作字符串以及过期时间

  1. 添加字符串         set key value

  2. 查看字符串.        get key

  3.  设置过期时间 

  • set key value EX 过期时间()   比如:set username axuan EX 10

  • expire key 过期时间()           比如:expire age 204. 查看过期时间  ttl key 

  1. 查看所有字符串     keys *

  2. 删除字符串          del key

其他命令: 

  • 删除所有的key  flushall
  • 六、 redis 列表操作

  • 在列表左边添加元素

         lpush key value             比如:lpush userlist xuan

  • 在列表右边添加元素

         rpush key value       

  • 查看列表中的元素

         lrange key start stop      比如:lrange userlist 0 -1 返回所有的元素

  • 移除并返回列表key的头元素

        lpop key

  • 移除并返回列表key的尾元素

        rpop key

  • 移除并返回返回列表key的中间元素,count个值为value的元素

        lrem key count value        比如:lrem userlist 1 haha

  • 指定返回第几个元素(元素序号是从0开始)

          lindex key index

  • 获取列表中的元素个数

          llen key

  • 删除指定的元素

        lrem key count value

         count > 0:从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count 。

         count < 0:从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值。

        count = 0: 移除表中所有与 value 相等的值。

七、redis 集合操作

  • 添加元素

        sadd set value1 value2 比如:sadd school1 qinghua beida

  • 查看元素

        smembers  set 比如:smembers school1

  • 移除元素

        srem set memeber  比如:srem school1 beida

  • 查看集合中的元素个数

        scard set 比如:scard school1

  • 获取多个集合的交集

        sinter set1 set2 比如sinter school1 school2

  • 获取多个集合的并集

        sunion set1 set2 比如:sunion school1 school2

  • 获取多个集合的差集

        sdiff set1 set2 比如:sdiff school1 school2

八、hash 哈希操作

  • 添加一个新值

        hset key field value 比如:hset person name xuan

  • 添加多个新值

        hmset key field value field value... 比如:hmset person address jueeweee height 155

  • 获取哈希中的field对应的值

        hset key field 比如:hget person name

  • 删除field 中的某个field

        hdel key field 比如:hdel person height

  • 获取某个哈希中所有的field 和 value

        hgetall key 比如:hgetall person

  • 获取某个哈希中所有的field

        hkeys key 比如:hkeys person

  • 获取某个哈希中所有的值

        hvals key 比如:hvals person

  • 判断哈希是否存在某个filed

          hexists key field 比如:hexists person age

  • 获取哈希中总共的键值对

        hlen key 比如:hlen person key

  1. redis 事务操作
  1. 事务特点

        Redis 事务可以一次执行多个命令,事务具有以下特征:

  • 隔离操作:事务中的所有命令都会序列化、按顺序地执行,不会被其他命令打扰。
  • 原子操作: 事务中的命令要么全部被执行,要么全部都不执行。

     2. 操作事务

  • 开启一个事务

        multi

  • 执行事务,会将在multi 和exec 中的操作一并提交

        exec

如下图所示:

127.0.0.1:6379> multi

OK

127.0.0.1:6379(TX)> set username axuanya

QUEUED

127.0.0.1:6379(TX)> get username

QUEUED

127.0.0.1:6379(TX)> exec

1) OK

2) "axuanya"

  • 取消事务

        discard

  • 监视一个或者多个key,如果在事务执行之前这个(或这些)key 被其他命令所改动,那么事务将被打断

 127.0.0.1:6379> watch username

OK

127.0.0.1:6379> multi

OK

127.0.0.1:6379(TX)> set username hahahaha

QUEUED

127.0.0.1:6379(TX)> exec

1) OK

127.0.0.1:6379> get username

"hahahaha"

127.0.0.1:6379>

  • 取消所有key的监视

        unwatch

九、redis 发布和订阅操作

  1. 给某个频道发布消息

        publish channel message

      2. 订阅某个频道发布消息

        subscribe channel

十、RDB和AOF的两种数据持久化机制

RDB

AOF

开启关闭

开启: 默认开启。关闭: 把配置文件中所有的save都注释,就是关闭了。

开启:在配置文件中appendonly ,yes 即开启了 aof ,为 no 关闭。

同步机制

可以指定某个时间内发生多少个命令进行同步。比如1分钟内发生了2次命令,就做一次同步。

*save 900 1:如果在900s以内发生了1次数据更新操作,那么就会做一次同步操作。

*save 300 10: 如果在300s以内发生了10数据更新操作,那么就会做一次同步操作。

*save 60 10000:如果在60s以内发生了10000数据更新操作,那么就会做一次同步操作。

每秒同步或者每次发生命令后同步。

*appendfsync always:每次有数据更新操作,都会同步到文件中。

* appendfsync everysec:每秒进行一次更新。

* appendfsync no:使用操作系统的方式进行更新。普遍是30s更新一次。

存储内容

存储的是redis里面的具体的值

存储的是执行的更新数据的操作命令

存储路径

根据redis.conf下的dir以及rdbfilename来指定的。默认是/var/lib/redis/dump.rdb

根据redis.conf下的dir以及appendfilename来指定的。默认是/var/lib/redis/dump.rdb

优点

  1.  存储数据到文件中会进行压缩,文件体积比aof小。(2) 因为存储的是redis具体的值,并且会经过压缩,因此在恢复的时候速度比AOF快。

(3)非常适用于备份。

(1) AOF的策略是每秒钟或者每次发生写操作的时候都会同步,因此即使服务器故障,最多只会丢失1秒的数据。(2) AOF存储的是Redis命令,并且是直接追加到aof文件后面,因此每次备份的时候只要添加新的数据进去就可以了。(3) 如果AOF文件比较大了,那么Redis会进行重写,只保留最小的命令集合。

缺点

  1. RDB在多少时间内发生了多少写操作的时候就会出发同步机制,因为采用压缩机制,RDB在同步的时候都重新保存整个Redis中的数据,因此你一般会设置在最少5分钟才保存一次数据。在这种情况下,一旦服务器故障,会造成5分钟的数据丢失。(2)在数据保存进RDB的时候,Redis会fork出一个子进程用来同步,在数据量比较大的时候,可能会非常耗时。
  1. AOF文件因为没有压缩,因此体积比RDB大。 (2) AOF是在每秒或者每次写操作都进行备份,因此如果并发量比较大,效率可能有点慢。(3)AOF文件因为存储的是命令,因此在灾难恢复的时候Redis会重新运行AOF中的命令,速度不及RDB。

十一、 其他机器连接redis

如果想要让其他机器连接本机的redis 服务器, 那么应该在redis.conf配置文件中,指定“bind 本机的ip地址”,

这样别的机器就能连接成功。不像是网上说的,要指定对方的ip地址.

十二、 python 操作redis

1. 安装python-redis  以及连接redis

import redis
from flask import Flask
cache = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
app = Flask(__name__)
if __name__ == '__main__':
    app.run(debug=True)

2. 操作数据

# 1. 操作字符串
cache.set('username', 'axuan')
print(cache.get('username'))
# 2. 操作列表
cache.lpush('languages', 'java')
cache.lpush('languages', 'python')
print(cache.lrange('languages', 0, -1))
# 3. 集合的操作
cache.sadd('team', 'yuyu')
cache.sadd('team', 'xuan')
print(cache.smembers('team'))
# 4. 哈希的操作
cache.hset('person','name','xuanya')
cache.hset('person','age','25')
print(cache.hgetall('person'))

3.  事务操作

pip=cache.pipeline()
pip.set('username','lalala')
pip.set('password','1u3u33')
# 执行事务
pip.execute()

4. 发布与订阅

# 订阅
ps = cache.pubsub()
ps.subscribe('email')
while True:
    for item in ps.listen():
        if item['type'] == 'message':
            print(item['data'])
# 发布
import redis
from faker import Faker
cache = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
fake = Faker(language='zh-CN')
for x in range(3):
    cache.publish('email', fake.email())

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2164307.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux】解锁文件描述符奥秘,高效缓存区的实战技巧

fd和缓冲区 1. 文件描述符fd1.1. 概念与本质1.2. 打开文件的管理1.3. 一切皆文件的理解1.4. 分配规则1.5. 重定向的本质1.5.1. dup2 2. FILE中的缓冲区2.1. 概念2.2. 存在的原因2.3. 类型(刷新方案)2.4. 存放的位置2.4.1. 代码证明、现象解释 2.5. 模拟C标准库中的方法 1. 文件…

LiveGBS流媒体平台GB/T28181功能-支持电子放大拉框放大直播视频拉框放大录像视频流拉框放大电子放大

LiveGBS流媒体平台GB/T28181功能-支持电子放大拉框放大直播视频拉框放大录像视频流拉框放大电子放大 1、直播播放2、录像播放3、搭建GB28181视频直播平台 1、直播播放 国标设备-》查看通道-》播放 &#xff0c;左键单击可以拉取矩形框&#xff0c;放大选中的范围&#xff0c;释…

IPD如何解决产品开发的典型问题

IPD&#xff08;Integrated Product Development&#xff0c;集成产品开发&#xff09;是一种领先的、成熟的产品开发的管理思想和管理模式。它是根据大量成功的产品开发管理实践总结出来的&#xff0c;并被大量实践证明的高效的产品开发模式。从汉捷咨询二十多年来为五百多家企…

如何通过代理使用 Squid: 综合指南

文章目录 一、简介二、什么是 Squid?三、为什么在代理服务器中使用 Squid&#xff1f;四、设置代理五、使用代理设置 Squid5.1. 第一步5.2. 第二步5.3. 第三步 六、在网络搜索中使用代理&#xff1a;实用代码示例6.1. 使用代理的 cURL6.2. 使用代理的 Python 请求 七、结论 一…

嘉立创EDA-- 线宽、过孔和电流大小对比图

导线宽度和电流大小如何来考虑 1 电流大小需要考虑问题 1、允许的温升&#xff1a;如果能够允许的铜线升高的温度越高&#xff0c;那么允许通过的电流自然也就越高 2、走线的线宽&#xff1a;线越宽 &#xff0c;导线横截面积越大&#xff0c;电阻越小&#xff0c;发热越小&a…

磨具生产制造9人共用一台工作站

随着技术的不断进步与工业自动化的深入发展&#xff0c;如何优化生产流程、提高设备利用率成为了众多企业面临的重大课题。那么在磨具生产制造中实现9人共用一台工作站呢&#xff1f; 一、背景与挑战 在磨具制造行业&#xff0c;高精度、高效率的生产要求与复杂多变的工艺流程…

smartctl 命令:查看硬盘健康状态

一、命令简介 ​smartctl​ 命令用于获取硬盘的 SMART 信息。 介绍硬盘SMART 硬盘的 SMART (Self-Monitoring, Analysis, and Reporting Technology) 技术用于监控硬盘的健康状态&#xff0c;并能提供一些潜在故障的预警信息。通过查看 SMART 数据&#xff0c;用户可以了解硬…

如何选择渲染集群管理软件?

选择适合渲染集群管理软件可以考虑以下几个方面&#xff1a; 1.渲染需求&#xff1a;明确自己的渲染任务类型、规模和复杂度。如果需要处理大型、复杂的项目&#xff0c;对渲染效率和速度要求较高&#xff0c;就需要选择性能强劲的软件。 2.软件兼容性&#xff1a;确保软件支持…

[极客大挑战 2019]EasySQL1

前言&#xff1a; 记录一下web方面的题(第一次接触。。。&#xff09; 学校课程要学web…… - - 行吧&#xff0c;尝试一下&#xff0c;至少学过MySQL。。。 不过&#xff0c;实际上&#xff0c;现实现在SQL漏洞少得可怜&#xff0c;但学习不会有错。 参考&#xff1a;&…

vue-cli,element-plus,axios,proxy

一、vue-cli vue-cli俗称vue脚手架&#xff0c;是vue官方提供的快速生成vue 工程化项目的工具。 1.官网&#xff1a;https://cn.vuejs.org/ 中文官网: https://cli.vuejs.org/zh/ 特点&#xff1a;基于webpack&#xff0c;功能丰富且易于扩展&#xff0c;支持创建vue2和vu…

学校快递站点管理|基于springboot学校快递站点管理设计与实现(源码+数据库+文档)

学校快递站点管理系统目录 目录 基于springboot学校快递站点管理设计与实现 一、前言 二、系统功能设计 三、系统实现 前台功能模块 后台功能角模块 四、数据库设计 1、实体ER图 2、具体的表设计如下所示&#xff1a; 五、核心代码 六、论文参考 七、最新计算机毕设…

本地搭建OnlyOffice在线文档编辑器结合内网穿透实现远程协作

文章目录 前言1. 安装Docker2. 本地安装部署ONLYOFFICE3. 安装cpolar内网穿透4. 固定OnlyOffice公网地址 前言 本篇文章讲解如何使用Docker在本地Linux服务器上安装ONLYOFFICE&#xff0c;并结合cpolar内网穿透实现公网访问本地部署的文档编辑器与远程协作。 Community Editi…

LVM的基本概念,PD PP PV VG LV PE等概念

LVM&#xff08;Logical Volume Manager&#xff0c;逻辑卷管理器&#xff09;是 Linux 系统中一种灵活的磁盘分区管理工具&#xff0c;允许动态地调整存储设备的大小和配置&#xff0c;而无需停止系统。LVM 在传统的分区管理工具上添加了更灵活的管理功能&#xff0c;特别适合…

逆向推理+ChatGPT,让论文更具说服力

学境思源&#xff0c;一键生成论文初稿&#xff1a; AcademicIdeas - 学境思源AI论文写作 使用ChatGPT辅助“逆向推理”技巧&#xff0c;可以显著提升论文的质量和说服力。逆向推理从结论出发&#xff0c;倒推所需的证据和论点&#xff0c;确保整个论证过程逻辑严密且无漏洞。…

Linux快速安装ClickHouse(附官方文档)

在线安装 1.安装yum-utils yum-utils是一个与 yum 集成的实用程序集合&#xff0c;可以通过多种方式扩展其本机功能 yum install -y yum-utils 2.增加ClickHouse官方镜像源 yum-config-manager --add-repo https://packages.clickhouse.com/rpm/clickhouse.repo 3.安装Cl…

【推荐100个unity插件之34】在unity中实现和Live2D虚拟人物的交互——Cubism SDK for Unity

最终效果 文章目录 最终效果前言例子中文官网Live2d模型获取下载Live2D Cubism SDK for Unity使用文档限制unity导入并使用Live2D模型1、将SDK载入到项目2、载入模型3、显示模型4、 播放动画 表情动作修改参数眼神跟随看向鼠标效果部位触摸效果摸头效果摸头闭眼效果做成桌宠参考…

企业如何通过ETL工具实现主数据的同步

1、 主数据的定义与重要性 主数据&#xff0c;作为企业的核心数据资产&#xff0c;涵盖了客户、产品、供应商、员工等关键业务实体信息。这些数据的稳定性、共享性和对决策的影响力&#xff0c;使其成为企业运营和战略决策不可或缺的基础。主数据的质量与一致性直接关系到企业…

数据结构-4.栈与队列

本篇博客给大家带来的是栈和队列的知识点, 其中包括两道面试OJ题 用队列实现栈 和 用栈实现队列. 文章专栏: Java-数据结构 若有问题 评论区见 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条, 如果分享不成功, 那我就会回你一下,那样你就分享成功啦. 你们的…

在Unity编辑器中实现组件的复制与粘贴:完整指南

内容将会持续更新&#xff0c;有错误的地方欢迎指正&#xff0c;谢谢! 在Unity编辑器中实现组件的复制与粘贴&#xff1a;完整指南 TechX 坚持将创新的科技带给世界&#xff01; 拥有更好的学习体验 —— 不断努力&#xff0c;不断进步&#xff0c;不断探索 TechX —— 心…

低空经济——载具

低空经济的政策大家都知道&#xff0c;开放低空&#xff0c;是经济和社会发展的需要&#xff0c;但是步子肯定不会太大&#xff0c;先刺激资本进行投入&#xff0c;之后看看再说&#xff0c;一定是这样模式。 我们知道&#xff0c;新能源车&#xff0c;基本实现了弯道超车&…