• Varnish 简介



    Varnish是高性能开源的反向代理服务器和HTTP缓存服务器


    Varnish的功能与Squid服务器相似,都可以用来做HTTP缓存


    Squid是从硬盘读取缓存的数据,而Varnish把数据存放在内存中,直接从读取内存,避免了频繁在内存、磁盘中交换文件,所以Varnish要相对更高效,但也有缺点,内存中的缓存在服务器重启后会丢失


    Varnish 如何工作


    初始化过程


    Varnish 的master进程负责启动工作,master进程读取配置文件,根据指定的空间大小(例如管理员分配了2G内存)来创建存储空间,创建并管理child进程


    child进程来处理后续任务,它会分配一些线程来执行不同的工作,例如


    接受http请求

    为缓存对象分配存储空间

    清除过期缓存对象

    释放空间 碎片整理


    http请求处理过程


    有一个专门负责接收http请求的线程,一直监听请求端口,当有请求过来时,负责唤起一个工作线程来处理请求


    工作线程会分析http请求的uri,知道了这个请求想要什么,就到缓存中查找是否有这个对象


    如果有,就把缓存对象直接返回给用户


    如果没有,会把请求转给后端服务器处理,并等待结果,工作线程从后端得到结果内容后,先把内容作为一个缓存对象保存到缓存空间(以备下次请求这个对象时快速响应),然后再把内容返回给用户


    分配缓存过程


    有一个对象需要缓存时,根据这个对象的大小,到空闲缓存区中查找大小最适合的空闲块,找到后就把这个对象放进去


    如果这个对象没有填满这个空闲块,就把剩余的空间做为一个新的空闲块


    如果空闲缓存区中没地方了,就要先删除一部分缓存来腾出地方,删除是根据最近最少使用原则


    释放缓存过程


    有一个线程来负责缓存的释放工作,他定期检查缓存中所有对象的生存周期,如果某个对象在指定的时间段内没有被访问,就把这个对象删除,释放其占用的缓存空间


    释放空间后,检查一下临近的内存空间是否是空闲的,如果是,就整合为一个更大的空闲块,实现空间碎片的整理

  • 相关阅读:
    [51单片机] TFT2.4彩屏1 [文字显示 画矩形]
    [51单片机] 中断1-中断整体介绍
    [汇编] 从键盘输入一个一位数字,然后响铃n声
    [汇编] 比较2个字符串是否相等
    [汇编] 将字符串里的一个'&'字符换成空格
    [汇编] 2数相加极简单版
    mysql的IFNULL函数
    mysql 中 unix_timestamp和from_unixtime函数
    Excel实现二级菜单联动
    Hibernate中@Embedded和@Embeddable注解
  • 原文地址:https://www.cnblogs.com/xmanblue/p/6497349.html
Copyright © 2020-2023  润新知