Django的缓存 CS与BS的区别
文章目录
一、Django的缓存
属于web项目优化策略
1. 缓存的概念
① 引入缓存的原因
缓存是一类快速读取数据的介质。把缓存指向快速读取数据的存储方式。常用的缓存介质是读取数据快的内存。一般来说:从数据库中多次将需要的数据库取出来要比从内存中或者硬盘一次性将数据取出来成本高。对于大中型网站而言,使用缓存较少了数据库的访问次数,从而提高网站的性能。
② 缓存的定义
缓存:缓存就是将数据提前放在一个地方(内存),等访问的时候,直接从缓存中返回数据,不需要再次查询数据库。
③ 缓存逻辑
判断想要的数据是否在缓存中:
- 是:
- 直接返回数据 - 否:
- 查询数据库
- 保存到缓冲中
- 返回数据
④ 常用的缓存:
Memcache 缓存 : 是分布式的高速缓存系统,是当下最火的,使用最多的。
二、在django项目中使用缓存
1. 本地安装memcache服务
① 安装解压后进入x64文件下
② 查看memcache服务 并启动
③ 安装 python-memcached
2. 配置 settings文件
找到全局文件,找到cache配置,全局文件路径如下:
配置cache(将上述文件的这些内容复制到settings.py并加入本地的memcache地址)
3. 使用
① 在视图中使用
运行后
② 路由中使用缓存
运行后
③ 在中间件中使用
作用范围:全局
④ 页面缓存
⑤ 视图内部数据的缓存
三、CS与BS的区别
cs client/server
bs brower/server
区别:
- 客户端负载
- cs负载大
- 更新维护,收集用户信息,和用户交互,发送请求。
- bs负载小,只负责展示,将逻辑处理和业务处理过程交给了服务器
- cs负载大
- 维护成本 版本迭代 bug修改 运维相关
- cs 大
- 下载更新包
- bs 小
- 只需要修改服务器
- cs 大
- 安全性
- cs 高
- 需要下载客户端
- bs 低
- 用户量群体较大,不固定,安全性低
- cs 高
四、数据库优化
数据库:
优化:
- sql语句
- 增
- 查
- select 字段
- 使用join 代替子查询
- 子查询
- where select name from stu where id in (select id from stu where age > 10);
- from select name from (select name,age from stu where age > 10 ) as nan where name = “zhangsan”;
- 子查询
- 索引 字段靠左原则 select * from stu where name = 10 and age = 20 and sex = nan;
- where group by having
- 改
- 删
- 表结构优化
-
字段
- 字段类型
- char varcar
- 字段类型
-
主键外键
- 分表
-
三范式
-
- 库结构的优化
- 分库
- 水平
- 垂直
- 分库
- 垂直分表
- 垂直分库
- 水平分表
- 主键唯一 主键全局唯一
- 水平分库分表
- 事务的处理 关联查询
- 阿里 腾讯 mysql官方,百度
- 数据库架构优化
性能不高 -》 IO操作
mysql数据存在硬盘
硬盘 -》》》 加载 ——》》 内存 ——》 读