Web 开发 6:Redis 缓存(Flask项目使用Redis并同时部署到Docker详细流程 附项目源码)

图片原地址https://unsplash.com/photos/body-of-water-8eO6zSoCKS8

大家好!欢迎来到第六篇 Web 开发教程,今天我们将探讨一个非常重要的话题:Redis 缓存。作为一个互联网开发者,你一定知道在处理大量请求时,性能优化是至关重要的。而 Redis 缓存正是帮助我们提升系统性能的利器。Redis 是一个流行的开源内存数据库,它提供了强大的缓存功能。

在本教程中,我们将学习如何在PyCharm 中使用 Flask 进行 Web 开发,并利用 Redis 缓存来优化我们的应用程序。

什么是 Redis?

Redis(Remote Dictionary Server)是一个开源的内存数据结构存储系统,它可以用作数据库、缓存和消息中间件。它支持多种数据结构,如字符串、哈希表、列表、集合和有序集合,并提供了丰富的操作命令。Redis 的特点是数据存储在内存中,因此具有非常高的读写性能。

为什么要使用 Redis 缓存?

在 Web 应用中,数据库是最常用的数据存储方式。然而,频繁地从数据库中读取数据会导致性能瓶颈,从而影响用户体验。这时候,使用 Redis 缓存可以显著提升系统性能。

Redis 缓存的工作原理

Redis 缓存的工作原理非常简单明了。当用户请求某个数据时,首先检查 Redis 缓存中是否存在该数据。如果存在,则直接从 Redis 中获取数据并返回给用户,避免了频繁访问数据库的开销。如果数据不存在于 Redis 缓存中,则从数据库中读取数据,并将数据存储到 Redis 缓存中,以便下次请求时可以直接从缓存中获取。

缓存命中率

在使用 Redis 缓存时,我们关注的一个重要指标是缓存命中率。缓存命中率是指从缓存中获取数据的次数与总请求次数的比例。高缓存命中率表示大部分数据都可以从缓存中获取,系统性能较好。而低缓存命中率则意味着缓存的效果不佳,需要优化缓存策略或增加缓存的数据范围。

如何使用 Redis 缓存?

使用 Redis 缓存的步骤如下:

  1. 安装和配置 Redis:首先,你需要在你的服务器上安装 Redis,并进行基本的配置。你可以在 Redis 的官方网站上找到安装和配置的详细指南。

  2. 选择缓存数据:根据你的应用需求,选择需要缓存的数据。通常,频繁读取且不经常变化的数据是最适合缓存的。

  3. 编写缓存逻辑:在你的应用程序中,编写缓存逻辑来处理数据的读取和写入。当需要读取数据时,首先检查 Redis 缓存中是否存在该数据,如果存在,则直接返回缓存数据;如果不存在,则从数据库中读取数据,并将数据存储到 Redis 缓存中。

  4. 设置缓存过期时间:为了避免缓存数据过期,你可以设置缓存数据的过期时间。当数据过期时,系统会重新从数据库中读取最新数据,并更新 Redis 缓存。

  5. 处理缓存更新:当数据发生变化时,你需要更新 Redis 缓存中的数据。这可以通过在数据更新的同时,更新 Redis 缓存来实现。

Redis 缓存的优势和注意事项

使用 Redis 缓存有以下优势:

提升系统性能

Redis 缓存可以减少对数据库的访问次数,从而提升系统的响应速度和并发能力。通过将常用的数据存储在内存中,系统可以快速地获取数据,而不需要频繁地访问数据库。

减轻数据库负载

通过缓存常用数据,可以减轻数据库的负载,提高数据库的处理能力。当数据被缓存后,系统可以直接从缓存中获取数据,而不需要每次都访问数据库,从而降低了数据库的压力。

支持高并发

Redis 是单线程的,但通过使用异步操作和多个 Redis 实例,可以实现高并发的读写操作。这使得 Redis 缓存成为处理高并发场景的理想选择。

然而,使用 Redis 缓存也需要注意以下事项:

缓存一致性

当数据发生变化时,需要及时更新 Redis 缓存,以保持数据的一致性。否则,缓存中的数据可能会与数据库中的数据不一致,导致数据错误。

内存管理

由于 Redis 数据存储在内存中,需要合理管理内存使用,避免内存溢出的问题。可以通过设置合理的缓存大小和过期时间来控制内存的使用。

缓存穿透

如果缓存中不存在某个数据,而且该数据频繁被请求,会导致大量请求直接访问数据库,从而降低性能。为了解决这个问题,可以使用布隆过滤器等技术来减少缓存穿透的发生。

接下来我们开始实战 创建 Flask 应用程序

首先,让我们创建一个新的 Flask 应用程序。打开 PyCharm,点击 “Create New Project”,然后选择 “Flask”
作为项目模板。输入项目名称和位置,然后点击 “Create”。

PyCharm 将为你创建一个基本的 Flask 应用程序结构,包括一个主应用程序文件和一个模板文件夹。

在 Flask 应用程序中使用 Redis 缓存

现在,让我们看一个在 Flask 应用程序中使用 Redis 缓存的示例。

比如我们如果想要缓存用户的登录信息,就可以使用 Redis 缓存来提高验证性能并减少数据库查询次数。下面是一个示例,展示了如何在
Flask 应用程序中使用 Redis 缓存来缓存用户的登录信息:

首先,确保已安装 Redis 客户端库 redis-py。可以使用以下命令进行安装:

pip install redis

然后,在 Flask 应用程序中导入 Redis 模块、Flask 模块和数据库模块,例如 SQLAlchemy:

from flask import Flask, render_template, request, redirect, session
from flask_sqlalchemy import SQLAlchemy
import redis

接下来,创建 Flask 应用程序实例、数据库实例和 Redis 客户端实例:

app = Flask(__name__)
app.secret_key = "your_secret_key"# 配置数据库连接
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///users.db'
db = SQLAlchemy(app)
redis_client = redis.Redis(host='my-redis', port=6379, db=0, password='123456')

然后,定义一个登录路由函数,该函数验证用户的登录信息并使用 Redis 缓存来存储登录状态:

@app.route('/login', methods=['GET', 'POST'])
def login():if request.method == 'POST':username = request.form['username']password = request.form['password']user = User.query.filter_by(username=username).first()if user and user.password == password:session['user_id'] = user.id# 将用户信息存储到 Redis 缓存中,设置过期时间为 1 小时redis_client.setex(user.id, 3600, user.username)return redirect('/')else:return "Invalid username or password"return render_template('login.html')

定义一个注册路由函数,注册用户的信息并使用 Redis 缓存来存储登录状态:

@app.route('/register', methods=['GET', 'POST'])
def register():if request.method == 'POST':username = request.form['username']email = request.form['email']password = request.form['password']# 检查邮箱是否已经存在existing_user = User.query.filter_by(email=email).first()if existing_user:return "Email already exists"new_user = User(username, email, password)db.session.add(new_user)db.session.commit()# 将用户信息存储到 Redis 缓存中,设置过期时间为 1 小时redis_client.setex(new_user.id, 3600, new_user.username)return redirect('/')return render_template('register.html')

Docker 上安装和配置 Redis 的流程

首先,确保已经安装了 Docker。 检查 Docker 是否已安装

docker --version

Docker 的配置和使用建议查看我的上一篇文章 Web开发5:第三方扩展与部署

Redis 配置文件示例 redis.conf

# Redis 配置文件# 设置密码认证
requirepass 123456# 在 bind 参数中,指定了 Redis 只允许本地连接(127.0.0.1)。
# 这意味着只有本地的应用程序可以连接到 Redis。
# 如果希望允许远程连接,请将 bind 参数设置为 Redis 服务器的 IP 地址或设置为空字符串(bind 0.0.0.0 或 bind "")
bind 0.0.0.0# 设置最大内存限制
maxmemory 1gb# 设置键过期时间
# 在这里添加其他的配置指令...

本地Docker 运行启动flask app 和 redis

1. 创建一个 Docker Compose 文件。在与你的 Flask 应用程序代码相同的目录中创建一个名为 docker-compose.yml 的文件,并将以下内容复制到文件中:

version: '3'
services:app:container_name: my-redis-app  # 设置 Flask 应用程序容器的名称build:context: .  # 设置构建上下文为当前目录dockerfile: Dockerfile  # 指定构建使用的 Dockerfileports:- 5000:5000  # 将主机的 5000 端口映射到容器的 5000 端口depends_on:- redis  # 指定 app 服务依赖于 redis 服务redis:image: redis  # 使用 Redis 官方镜像container_name: my-redis  # 设置 Redis 容器的名称ports:- 6379:6379  # 将主机的 6379 端口映射到容器的 6379 端口volumes:- ./redis.conf:/usr/local/etc/redis/redis.conf  # 将主机上的 redis.conf 文件挂载到容器内指定的路径command: redis-server /usr/local/etc/redis/redis.conf  # 指定在容器内运行的 Redis 服务器命令

2. 启动容器。在终端中,进入包含 Docker Compose 文件的目录,并运行以下命令启动容器:

docker-compose up

这将启动两个容器:Flask 应用程序容器和 Redis 容器。你应该能够在终端中看到应用程序的日志输出。

在这里插入图片描述

演示

没有启动redis

在这里插入图片描述

启动redis

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
可以看到我们登录时先判断的redis缓存,从缓存中拿的数据,这样就减少了对数据库的查询访问。

项目源码

结论

在本教程中,我们学习了如何在 PyCharm 中使用 Flask 进行 Web 开发,并利用 Redis 缓存来提高应用程序的性能。我们了解了如何连接Redis 服务器,以及如何使用 Redis 缓存来存储和获取数据。通过使用 Redis 缓存,我们可以减少对其他数据源的访问,提高应用程序的响应速度。

希望这篇教程对你有所帮助!如果你有任何问题或反馈,请随时在下面的评论中提出。

Happy coding!🚀

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

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

相关文章

四川古力未来科技公司抖音小店选品攻略从零到一

随着抖音的日益火爆,抖音小店也应运而生,成为了电商行业的新宠儿。但对于许多新手商家来说,如何从众多的商品中挑选出适合自己店铺的商品,却是一件非常头疼的事情。本文将为你揭秘抖音小店的选品攻略,让你轻松玩转电商…

A股风格因子看板 (2024.01 第10期)

该因子看板跟踪A股风格因子,该因子主要解释沪深两市的市场收益、刻画市场风格趋势的系列风格因子,用以分析市场风格切换、组合风格暴 露等。 今日为该因子跟踪第10期,指数组合数据截止日2023-12-31,要点如下 近1年A股风格因子检验…

网络安全面试你应该准备什么?

年底,刚过了校招和跳槽的密集阶段,有的同学拿到了心仪的Offer,有的同学却铩羽而归。星球里也有小伙伴提出了这样的问题:安全相关的工作,有没有什么面试技巧呢? 由于安全门类巨大,涉及的技术很多…

Python进阶(1) | 使用VScode写单元测试

Python进阶(1) | 单元测试 2024.01.28 VSCode: 1.85.1 Linux(ubuntu 22.04) 文章目录 Python进阶(1) | 单元测试1. 目的2. Python Profile3. 单元测试框架3.1 什么是单元测试3.2 选一个单元测试框架3.3 编写 Python 单元测试代码3.4 在 VSCode 里发现单元测试3.5 再写一个单元…

【MySQL】补充和navicat的一些简单使用

文章目录 前言在这里插入图片描述 事情起因因为这个articlecount的c是小写了,我想改成大写 一、修改二、navicat的使用步骤1.连接2.建库,建表 三.填写数据总结 前言 事情起因因为这个articlecount的c是小写了,我想改成大写 提示:…

Redis 学习笔记 2:Java 客户端

Redis 学习笔记 2:Java 客户端 常见的 Redis Java 客户端有三种: Jedis,优点是API 风格与 Redis 命令命名保持一致,容易上手,缺点是连接实例是线程不安全的,多线程场景需要用线程池来管理连接。Redisson&…

一文搞懂设计模式—策略模式

本文已收录至Github,推荐阅读 👉 Java随想录 微信公众号:Java随想录 文章目录 使用场景策略模式实现策略模式的优缺点策略模式优化使用Map取消 Context 类策略枚举解决策略类膨胀SpringBoot中的策略模式 总结 在软件开发中,经常会…

pcl应用八叉树实例

pcl应用八叉树实例 文章目录 pcl应用八叉树实例1、基本概念2、基于八叉树的空间划分及搜索操作2.1、关键函数说明2.1.2 OctreePointCloudSearch 类2.1.2 voxelSearch 函数 3、无序点云数据集的空间变化检测 1、基本概念 八叉树结构通过循环递归的划分方法对大小为2 n ∗ 2 n ∗…

C++面试宝典第25题:阶乘末尾零的个数

题目 给定一个整数n,返回n!(n的阶乘)结果尾数中零的个数。 示例 1: 输入:3 输出:0 解释:3! = 6,尾数中没有零。 示例 2: 输入:5 输出:1 解释:5! = 120,尾数中有1个零。 解析 这道题主要考察应聘者对于数学问题的分析和理解能力,以及在多个解决方案中,寻求最优…

elementUI的el-select传递item对象或其他参数的2种方法

方法1 :value“item” 绑定对象 只要:value绑定item对象就可以 value-key"value" 必须是item里的一个属性&#xff0c;绑定值为对象类型时必填 <el-select v-model"value" placeholder"请选择" value-key"value" change"cha…

(蓝桥杯每日一题)求最长回文串

问题描述 给出一个长度为 n 的小写字符串&#xff0c;求一个最长的子串 S&#xff0c;满足SXY,X&#xff0c;Y>1&#xff0c;且X,Y 均为回文串。 输入格式 输入包括一行: 第一行是一个长度为 n 的小写字符串。 输出格式 输出包括一行&#xff1a; 一行一个整数&#xff0c;表…

Material Components for Android助你打造精美App

Material Components for Android助你打造精美App 简介 Material Components for Android (MDC-Android) 是帮助开发者执行 Material Design 的工具。由谷歌的核心工程师和用户体验设计师团队开发&#xff0c;这些组件使得开发者可以可靠地开发工作流来构建美观且功能齐全的 …

期权定价模型系列[9]SABR模型

1.简介 SABR模型是由 Hagan在 2002年提出的一种随机波动率模型&#xff0c;在抛弃了原始的BSM 模型中对于波动率为某一常数的假定&#xff0c;假设隐含波动率同样是符合几何布朗运动的&#xff0c;并且将隐含波动率设定为标的价格和合约行权价的函数&#xff0c;结合了隐含波动…

12.5内存操作流(血干JAVA系列)

12.5内存操作流 12.5内存操作流ByteArraylnputStream类的主要方法ByteArrayOutputStream 类的主要方法【例12.33】使用内存操作流完成一个大写字母转换为小写字母的程序 12.5内存操作流 在 流 的 操 作 中 除 了 进 行 文 件 的 输 入 与 输 出 操 作 之 外 &#xff0c; 也 可…

flask初体验

1、定义 Flask是一个Python编写的Web 微框架,让我们可以使用Python语言快速实现一个网站或Web服务。 中文官网 2、初步上手 1、安装flask pip3 install flask 2、创建flask应用 # -*- coding = utf-8 -*- # @Time : 2024/1/28 23:02 # @Author: Frank # @File: main.py…

说说你对vue的mixin的理解,有什么应用场景

mixin是什么 Vue中的mixin 局部混入全局混入注意事项: 使用场景源码分析Vue 的几种类型的合并策略 替换型合并型队列性叠加型小结 此文章&#xff0c;来源于印客学院的资料&#xff0c;这里只是分享&#xff0c;便于查漏补缺。 mixin是什么 Mixin 是 面向对象程序设计语言中…

回归预测 | MATLAB实现PSO-GRNN粒子群优化广义回归神经网络多输入单输出预测(含优化前后预测可视化)

回归预测 | MATLAB实现PSO-GRNN粒子群优化广义回归神经网络多输入单输出预测 目录 回归预测 | MATLAB实现PSO-GRNN粒子群优化广义回归神经网络多输入单输出预测预测效果基本介绍程序设计参考资料预测效果 <

爬虫基础-计算机网络协议

一个数据的传输 这些设备的数据转发是通过协议来完成的&#xff0c;整个互联网可以说是完全由网络协议来维持的 不同的协议分工不同&#xff0c;比如ip协议确保了ip寻址&#xff0c;tcp协议确保了数据完整性 IP地址和URL ip地址 整个网络传输可以比作快递&#xff0c;数据就…

使用毫米波雷达传感器的功能安全兼容系统设计指南1(TI文档)

摘要 功能安全标准规定了在系统中实施安全的要求&#xff0c;并有助于概括该系统要达到的安全目标。包括功能安全的系统设计不仅要降低操作不当的风险&#xff0c;还要检测故障并将其影响降到最低。随着汽车和工业系统的自主性越来越强&#xff0c;严格的功能安全要求被强制执行…

(28)Linux 信号保存 信号处理 不可重入函数

首先介绍几个新的概念&#xff1a; 信号递达(Delivery)&#xff1a;实际执行信号的处理动作。信号未决(Pending)&#xff1a;信号从产生到递达之间的状态。信号阻塞(Block)&#xff1a;被阻塞的信号产生时将保持在未决状态&#xff0c;直达解除对该信号的阻塞&#xff0c;才执…