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  # 指定构建使用的 Dockerfile
    ports:
      - 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!🚀

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

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

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

2023年度总结——忙忙碌碌,终有归章

思来想去,还是决定写一篇年终总结,一来算是对23年的一年的回顾,二来是对24年的展望。记得22年也写过一篇年度总结,题目是《2022年度总结——一切都在慢慢变好》。今年,我想起的题目是《2023年度总结——忙忙碌碌&#…

在Temu跨境电商平台上,如何快速出单?

随着越来越多的商家选择入驻Temu跨境电商平台,一旦入驻申请通过,商家就可以开始上架商品并等待订单的产生。然而,很多新手跨境电商卖家都面临一个共同的问题,那就是:Temu出单快吗?Temu上架多久能出单&#…

STM32CubeMX教程27 SDIO - 读写SD卡

目录 1、准备材料 2、实验目标 3、轮询方式读取SD卡流程 3.0、前提知识 3.1、CubeMX相关配置 3.1.0、工程基本配置 3.1.1、时钟树配置 3.1.2、外设参数配置 3.1.3、外设中断配置 3.2、生成代码 3.2.0、配置Project Manager页面 3.2.1、外设初始化调用流程 3.2.2、外设中断调用流…

激光雷达,角力「降本增效」

高工智能汽车研究院最新发布的数据显示,2023年1-11月,中国市场(不含进出口)乘用车前装标配激光雷达搭载量为46.48万颗,同比增长372.35%,继续保持高增长态势。 随着激光雷达在中国市场完成规模化上量的节点&…

Promethues是什么?

什么是Prometheus? Prometheus是一个开源的系统监控以及报警系统。整和zabbix的功能,系统,网络,设备。 promethues可以兼容网络、设备、容器监控、告警系统。因为和k8s是一个项目基金开发的产品,天生就匹配k8s的原生…

离线安装nginx_银河麒麟系统_nginx报错_503_500 Internal Server Error----nginx工作笔记007

如果报这个错误,意思就是,对于nginx.conf文件中指定的,文件夹没有权限 那么这个是去给对应的文件夹赋权限: chmod 777 /opt/module/test_web 就可以了,然后再去访问就不会报错了,还有 503的错误都可以这样解决 然后关于离线安装nginx,尝试了一下如果把之前安装过的nginx,直接…

AI-数学-高中-10-2-分数指数幂计算

原作者视频:初等函数】2分数指数幂的计算(基础)_哔哩哔哩_bilibili 方法1: 方法2:

Matlab绘图技巧-NAN元素绘图出现锯齿状解决办法

Matlab绘图技巧-NAN元素绘图出现锯齿状解决办法 想必有很多同学遇到绘制3维曲面热力图,有一些数据是nan,绘制出来的图会出现锯齿状:如下图:    如果用matlab直接绘制带nan的矩阵的话,则会像上图一样,当然…

【教程】iOS 手机抓包工具介绍及教程

📱 最近又发现APP Store一款宝藏软件,克魔助手抓包工具,app刚上架,功能不断迭代中,目前18软妹币实惠价可享受终身版!现在是下手的最好时机。 引言 移动端开发中,抓包工具已成为必备的工具之一…

电脑文件夹怎么加密保护?文件夹加密软件推荐

电脑文件夹可以帮助我们管理各种文件,而文件夹加密则可以有效地保护数据安全。那么,电脑文件夹该怎么加密保护呢?下面我们就一起来了解一下。 超大文件夹加密 电脑中会有一些存放着视频、图纸等大文件的文件夹。这些文件夹体积庞大&#xff…

面试官:Mysql中EXISTS与IN的使用有哪些差异

在数据库查询优化中,查询效率直接关系到应用程序性能。其中,IN和EXISTS是两种常见的子查询操作符,广泛应用于SQL查询语句,但它们在执行效率上有所不同。 本文深入探讨IN和EXISTS的工作原理,以及在何种情境下选择更为合…

QGIS使用地理配准将3857坐标系转成上海城建坐标

控制点格式 如 mapX mapY sourceX sourceY enable dX dY residual -58653 70641 13452659.39 3746386.025 1 0 0 0 -58653 65641 13452693.09 3740477.283 1 0 0 0 ......保存为.points格式 图层预处理 图层投影为3857坐标系 地理配准 1. 打开图层-地理配准 工具 2. 导入…

ATAC-seq发篇测序文章就结束了吗?看如何利用ATAC-seq数据为后续关键基因的转录调控研究提供重要依据

染色质可及性(Chromatin Accessibility)是染色质的一种特性,为转录因子结合靶基因提供了空间。转座酶可及染色质测序分析(ATAC-seq)是常见的研究染色质可及性的方法,ATAC-seq联合RNA-seq是一种新的研究思路…

day10 Javaweb

第一章 WEB概述 1.1 JAVAWEB简介 用Java技术来解决相关web互联网领域的技术栈.使用JAVAEE技术体系开发企业级互联网项目. 项目规模和架构模式与JAVASE阶段有着很大的差别. 在互联网项目下,首先需要明白客户端和服务器的概念 客户端 :与用户进行交互,用于接收用户的…

解决ubuntu 在VMware Workstation Pro下显示不完整的问题

步骤一 ctrlaltT 打开终端,输入: xrandr -s 1920x1080如果报错就输入xrandr,从里面选择适合的分辨率 注意是字母x不是乘号 步骤二 按win键,在搜索框搜索resolution更改显示器分辨率: 选择与电脑相同的分辨率,点击…

(二十一)Flask之上下文管理第二篇(细细扣一遍源码)

每篇前言: 🏆🏆作者介绍:【孤寒者】—CSDN全栈领域优质创作者、HDZ核心组成员、华为云享专家Python全栈领域博主、CSDN原力计划作者 🔥🔥本文已收录于Flask框架从入门到实战专栏:《Flask框架从入…

【MISRA C 2012】Rule 5.6 类型定义名称应该是唯一的标识符

1. 规则1.1 原文1.2 分类 2. 关键描述3. Example4. 代码实例 1. 规则 1.1 原文 1.2 分类 规则5.6:类型定义名称应该是唯一的标识符 Required要求类规范。 2. 关键描述 typedef名称在所有名称空间和翻译单元中应该是唯一的。只有当类型定义在头文件中并且该头文件…

HiveSQL题——窗口函数(lag/lead)

目录 一、窗口函数的知识点 1.1 窗户函数的定义 1.2 窗户函数的语法 1.3 前后函数:lag/lead 二、实际案例 2.1 股票的波峰波谷 0 问题描述 1 数据准备 2 数据分析 3 小结 2.2 前后列转换(面试题) 0 问题描述 1 数据准备 2 数据分析 3 小结…

【C语言】linux内核ipoib模块 - ipoib_netdev_ops_pf结构

一、ipoib_netdev_ops_pf结构 static const struct net_device_ops ipoib_netdev_ops_pf {.ndo_init ipoib_ndo_init,.ndo_uninit ipoib_ndo_uninit,.ndo_open ipoib_open,.ndo_stop ipoib_stop,.ndo_change_mtu ipoib_change_mtu,.ndo_…