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

news2024/11/18 1:38:48

图片原地址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!🚀

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

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

相关文章

tcpdump 抓包无法落盘

文章目录 问题背景解决办法 问题背景 在嵌入式设备中(Linux系统),为了分析两个网络节点的通讯问题,往往需要用到tcpdump,抓一个.pcap的包在PC端进行分析。博主在实际操作中发现,抓包无法实时落盘。 解决办法 # 下面的命令是写在…

MATLAB环境下一种贝叶斯稀疏盲反卷积算法

稀疏盲反卷积贝叶斯估计方法通常使用伯努利-高斯分布(BG)先验的稀疏序列建模,并利用马尔可夫链蒙特卡罗(MCMC)方法进行未知估计。然而,BG模型的离散性会有计算瓶颈。为了解决这个问题,提出一个替代方案,采用MCMC方法对稀疏序列进行…

Mac下查看、配置和使用环境变量

Mac下查看、配置和使用环境变量 一:Mac怎么查看环境变量命令 printenv一:这个命令会一次性列出所有环境变量的键值对,输出格式为: VAR1value1 VAR2value2 ...二: 也可以通过给这个命令加上环境变量名参数&#xff0…

Linux CPU 负载说明

一、背景 工作中我们经常遇到CPU 负载高,CPU负载高意味着什么? CPU的负载是怎么计算的? top指令中的各个指标代表什么含义? 二、CPU 负载计算方法 在系统出现负载问题,通常会使用uptime和top确认负载,这两…

云微呼云呼叫中心:颠覆传统客户服务模式的数字化创新

1. 引言 随着云计算技术的不断成熟和普及,云呼叫中心作为一种全新的客户服务解决方案,正在以其高效、灵活和智能的特点,逐渐颠覆传统的客户服务模式。本文将深入探讨云呼叫中心的定义、特点、优势以及对企业的重要意义。 2. 云呼叫中心的定…

龙行龘龘•前程朤朤 | 联诚发2023年度述职大会与年会圆满举行

1月27日上午,以“不忘初心・砥砺前行”为主题的2023年度述职大会在联诚发深圳总部隆重举行,本次大会总结了过去一年的成就与不足,展望了未来一年的方向和目标。联诚发创始人兼总裁龙平芳、董秘毛强军、各部门负责人以及深圳总部全体职工出席了…

JSP概述和基本使用

1,JSP 概述 JSP(全称:Java Server Pages):Java 服务端页面。是一种动态的网页技术,其中既可以定义 HTML、JS、CSS等静态内容,还可以定义 Java代码的动态内容,也就是 JSP HTML Jav…

LabVIEW探测器CAN总线系统

介绍了一个基于FPGA和LabVIEW的CAN总线通信系统,该系统专为与各单机进行系统联调测试而设计。通过设计FPGA的CAN总线功能模块和USB功能模块,以及利用LabVIEW开发的上位机程序,系统成功实现了CAN总线信息的收发、存储、解析及显示功能。测试结…

【更新】省级产业结构合理化+高度化+高级化数据(2000-2022年)

数据指标测算: (1)参考袁航等人(2018)的测算方法,采用泰尔指数来衡量产业结构合理化指标,用产业结构层次系数来表示产业结构高度化指标: (2)参考张欣艳等人&…

免费分享一套微信小程序外卖跑腿点餐(订餐)系统(uni-app+SpringBoot后端+Vue管理端技术实现) ,帅呆了~~

大家好,我是java1234_小锋老师,看到一个不错的微信小程序外卖跑腿点餐(订餐)系统(uni-appSpringBoot后端Vue管理端技术实现) ,分享下哈。 项目视频演示 【免费】微信小程序外卖跑腿点餐(订餐)系统(uni-appSpringBoot后端Vue管理端技术实现)…

解锁亚马逊鲲鹏系统奥秘:自动生成AI角色,随心定制养号计划

亚马逊鲲鹏系统是一款强大的软件,是一款可以批量注册亚马逊买家账号并能自动化养号的软件。其独特的功能和操作流程使得用户能够轻松管理多个账号,实现高效的运营和管理。 首先,该软件提供了AI智能养号功能,用户可以自动生成具有真…

TensorFlow2实战-系列教程4:数据增强:keras工具包/Data Augmentation

🧡💛💚TensorFlow2实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Jupyter Notebook中进行 本篇文章配套的代码资源已经上传 对于图像数据,将其进行翻转、放缩、平移、旋转操作就可以得到一组新的数据…

【JavaScript基础入门】05 JavaScript基础语法(三)

JavaScript基础语法(三) 目录 JavaScript基础语法(三)数组概述数组语法多维数组 操作数组修改数组获取数组长度数组和字符串之间的转换添加和删除数组项 Null 和 Undefined字符串连接字符串字符串转换获取字符串的长度在字符串中查…

Python之代码覆盖率框架coverage使用介绍

Python代码覆盖率工具coverage.py其实是一个第三方的包,同时支持Python2和Python3版本。 安装也非常简单,直接运行: pip install coverage 安装完成后,会在Python环境下的\Scripts下看到coverage.exe; 首先我们编写…

Linux(4)——Linux用户和用户组管理

Linux用户和用户组管理 插播!插播!插播!亲爱的朋友们,我们的Cmake/Makefile/Shell这三个课程上线啦!感兴趣的小伙伴可以去下面的链接学习哦~ 构建工具大师-CSDN程序员研修院 Linux用户和用户组管理是系统管理中非常重…

SharedPreferences卡顿分析

SP的使用及存在的问题 SharedPreferences(以下简称SP)是Android本地存储的一种方式,是以key-value的形式存储在/data/data/项目包名/shared_prefs/sp_name.xml里,SP的使用示例及源码解析参见:Android本地存储之SharedPreferences源码解析。以…

条件变量、线程池以及线程的GDB调试学习笔记

目录 一、条件变量 二、线程池概念和实现 三、线程的GDB调试 一、条件变量 应用场景:生产者消费者问题,是线程同步的一种手段。 必要性:为了实现等待某个资源,让线程休眠,提高运行效率 使用步骤: 初始…

【ArcGIS微课1000例】0096:dem三维块状表达(层次地形模型)

文章目录 一、DEM表达方式二、层次模型表达三、注意事项一、DEM表达方式 DEM数字高程模型的表达方式通常有以下4种: 1. 规则格网 2. 不规则三角网 3. 等高线 4. 层次地形模型 作为栅格地理数据,DEM 数据具有2.5维的特征,能够以三维表面的形式进行三维空间表达。但受其数…

幻兽帕鲁Linux私服搭建备份迁移指南

幻兽帕鲁Linux私服搭建指南 文档参考 !!!说明:不只是幻兽帕鲁,后续大家想自己搭私服玩别的Steam游戏,大部分内容都可以做一个参考 Linux安装steamcmd Linux开服步骤 游戏配置修改 Youtobe视频教程 配…

Linux中禅道12.5一键部署安装过程笔记

1. Linux中禅道12.5一键部署安装过程笔记 文章目录 1. Linux中禅道12.5一键部署安装过程笔记1. 安装1.将安装包直接解压到/opt目录下2. Apache和Mysql常用命令3. 访问和登录禅道4. 其他 2. 访问数据库1. 网页登录数据库2. 命令行连接数据库 3. 9.2.stable版本起Linux一键安装包…