实现的途径:expire cache-control

更新缓存的机制

如何校验本地缓存是否过期

expires cache-control(max-age)如果超期,说明失效

然后进行etag是否过期(是一串字符串)优先校验 先用etag,如果没有---last-modified

last-modified---具体的时间 过期时间时分秒----http request头信息

配置语法

304---缓存和修改时间没有更新,就提示 not modified

如果客户端(request-header)加入了请求头 cache-control max-age=0 ,那么意味着每次请求都要到服务端校验。通常用请求头last-modified对比 服务端文件的修改时间,从而得出是否缓存更新;这样做的好处是可以实时请求服务端的文件更新,坏处是不断向服务端发起连接请求,没利用上缓存

86400秒=24小时 代理缓存,动态缓存都依赖response head的cache-control

  • nginx缓存类型

网站都尽可能减少对后端的访问,从而把资源放到前端的nginx缓存中,

缓存放服务端---服务端缓存常见的是key-value,常见的是数据放在memocache,redis

代理中间件---代理缓存,  从服务端获取到缓存到本地,放在nginx一端

客户端缓存----放在浏览器上

nginx代理缓存的流程

配置语法

配置缓存过期周期

配置缓存维度:$scheme----缓存的协议;$proxy_host主机名;$request_url---url链接

测试场景:

主机启动8001,8002,8003这三个端口

设置

上图proxy_cache_path 参数下 定义了存放缓存的路径,文件夹分级方式:2层文件夹,keys_zone是为缓存命名inactive=60m,意味着60分钟内该缓存如果未被访问将被淘汰掉

use_temp_path默认是关闭,如果开启会出现和缓存文件夹 /opt/app/cache共存的局面;从而在缓存加载的过程中出现一些性能问题

其他配置信息:proxy_cache_valid 200 304 意味着状态200,状态304下返回的头信息 超时时间是12小时

proxy_cache_valid_any 10m 除了状态200 和 304 其他状态下返回头信息只保留10分钟

proxy_next_upstream 遇到下列情况,换服务器服务:遇到状态500,502,503 504;超时;提示错误

add_header添加请求信息头 Nginx_cache

把proxy_cache_调为off,就能访问不同的服务端返回页面了,如下图

清理指定缓存的方法

如何让页面不缓存

针对特别页面设置不缓存的代码

一个很特别的删除语句

大文件分片请求 slice 后面的size 就是分片文件大小

原理,先提交请求到后端,然后拿到请求的文件大小,然后根据slice size进行切片,形成一个个独立的小文件,分别请求服务后端

优势:每个子请求收到的数据都会形成一个独立文件,一个请求断了,其他的请求不受影响

缺点:一次请求会建立一个操作系统句柄,如果文件很大slice size很小就会造成很多个请求,造成建立多个连接和多个句柄

nginx 缓存,大文件分片请求方法的更多相关文章

  1. js实现大文件分片上传的方法

    借助js的Blob对象FormData对象可以实现大文件分片上传的功能,关于Blob和FormData的具体使用方法可以到如下地址去查看FormData 对象的使用Blob 对象的使用以下是实现代码, ...

  2. PHP大文件分片上传的实现方法

    一.前言 在网站开发中,经常会有上传文件的需求,有的文件size太大直接上传,经常会导致上传过程中耗时太久,大量占用带宽资源,因此有了分片上传. 分片上传主要是前端将一个较大的文件分成等分的几片,标识 ...

  3. nodeJs + js 大文件分片上传

    简单的文件上传 一.准备文件上传的条件: 1.安装nodejs环境 2.安装vue环境 3.验证环境是否安装成功 二.实现上传步骤 1.前端部分使用 vue-cli 脚手架,搭建一个 demo 版本, ...

  4. iOS大文件分片上传和断点续传

    总结一下大文件分片上传和断点续传的问题.因为文件过大(比如1G以上),必须要考虑上传过程网络中断的情况.http的网络请求中本身就已经具备了分片上传功能,当传输的文件比较大时,http协议自动会将文件 ...

  5. Node + js实现大文件分片上传基本原理及实践(一)

    _ 阅读目录 一:什么是分片上传? 二:理解Blob对象中的slice方法对文件进行分割及其他知识点 三. 使用 spark-md5 生成 md5文件 四. 使用koa+js实现大文件分片上传实践 回 ...

  6. PHP大文件分片上传

    前段时间做视频上传业务,通过网页上传视频到服务器. 视频大小 小则几十M,大则 1G+,以一般的HTTP请求发送数据的方式的话,会遇到的问题:1,文件过大,超出服务端的请求大小限制:2,请求时间过长, ...

  7. JSP大文件分片上传

    核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...

  8. php+html5实现无刷新上传,大文件分片上传,断点续传

    核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...

  9. .NET Core Web APi大文件分片上传研究

    前言 前两天发表利用FormData进行文件上传,然后有人问要是大文件几个G上传怎么搞,常见的不就是分片再搞下断点续传,动动手差不多也能搞出来,只不过要深入的话,考虑的东西还是很多.由于断点续传之前写 ...

随机推荐

  1. poco编译与运行

    1.引言 Poco C++库是: 一系列C++类库,类似Java类库,.Net框架,Apple的Cocoa; 侧重于互联网时代的网络应用程序 使用高效的,现代的标准ANSI/ISO C++,并基于ST ...

  2. 18.linux日志收集数据到hdfs上面

    先创建一个目录 在这个job目录下创建upload.sh文件 [hadoop@node1 ~]$ pwd /home/hadoop [hadoop@node1 ~]$ mkdir job [hadoo ...

  3. linux用户和组 之 用户管理

    一. linux 用户和组的基本介绍 1.linux下 有三种用户: 1. root: 权限最大的. 2. 系统用户: UID小于1000的.系统服务管理用户,一般是不允许登录系统的.(比如mysql ...

  4. Java实现链队

    一.分析 队列是一种先进先出的线性表,它只允许在表的一端进行插入,而在另一端删除元素.允许插入的一端称为队尾,允许删除的一端称为队头. 链队是指采用链式存储结构实现的队列,它的基本操作如下: 1.初始 ...

  5. Hinton等人新研究:如何更好地测量神经网络表示相似性

    Hinton等人新研究:如何更好地测量神经网络表示相似性 2019年05月22日 08:39:15 喜欢打酱油的老鸟 阅读数 177更多 分类专栏: 人工智能   https://www.toutia ...

  6. Autofac通过配置的方式

    autofac是比较简单易用的IOC容器.下面我们展示如何通过json配置文件,来进行控制反转. 需要用到以下程序集.可以通过nugget分别安装 Microsoft.Extensions.Confi ...

  7. 《深入实践C++模板编程》之二——模板类

    1.类的模板的使用 类,由于没有参数,所以没有模板实参推导机制. #include <stdexcept> template<typename T> class my_stac ...

  8. SQL SERVER 语法

    1.获取所有用户名: Select name FROM Sysusers where status='2' and islogin='1' islogin='1' :表示帐户 islogin='0' ...

  9. Flink的时间类型和watermark机制

    一FlinkTime类型 有3类时间,分别是数据本身的产生时间.进入Flink系统的时间和被处理的时间,在Flink系统中的数据可以有三种时间属性: Event Time 是每条数据在其生产设备上发生 ...

  10. JS基础_流程控制语句

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...