热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

VarnishCDN加速的实现(单个后端服务器)

一.Varnish简介

  • Varnish是什么?
    Varnish是一款高性能的开源HTTP加速器,挪威最大的在线报纸 Verdens Gang 使用3台Varnish代替了原来的12台Squid,性能比以前更好。
  • 简介:
    1.Varnish 的作者Poul-Henning Kamp是FreeBSD的内核开发者之一,他认为现在的计算机比起1975年已经复杂许多。在1975年时,储存媒介只有两种:内存与硬盘。但现在计算机系统的内存除了主存外,还包括了CPU内的L1、L2,甚至有L3快取。硬盘上也有自己的快取装置,因此Squid Cache自行处理物件替换的架构不可能得知这些情况而做到最佳化,但操作系统可以得知这些情况,所以这部份的工作应该交给操作系统处理,这就是 Varnish cache设计架构。
    2.varnish项目是2006年发布的第一个版本0.9.距今已经有十多年了,此文档之前也提过varnish还不稳定,那是2007年时候编写的,经过varnish开发团队和网友们的辛苦耕耘,现在的varnish已经很健壮。很多门户网站已经部署了varnish,并且反应都很好,甚至反应比squid还稳定,且效率更高,资源占用更少。相信在反向代理,web加速方面,varnish已经有足够能力代替squid。
  • Varnish工作流程?
    1.Varnish与一般服务器软件类似,分为master(management)进程和child(worker,主要做cache的工作)进程。master进程读入命令,进行一些初始化,然后fork并监控child进程。child进程分配若干线程进行工作,主要包括一些管理线程和很多woker线程。
    2.针对文件缓存部分,master读入存储配置(-s file[,path[,size[,granularity]]] ),调用合适的存储类型,然后创建/读入相应大小的缓存大文件。接着,master初始化管理该存储空间的结构体。这些变量都是全局变量,在fork以后会被child进程所继承(包括文件描述符)。
    3.在child进程主线程初始化过程中,将前面打开的存储大文件整个mmap到内存中(如果超出系统的虚拟内存,mmap失败,进程会减少原来的配置mmap大小,然后继续mmap),此时创建并初始化空闲存储结构体,挂到存储管理结构体,以待分配。
    4.接着,真正的工作开始,Varnish的某个负责接受新HTTP连接的线程开始等待用户,如果有新的HTTP连接过来,它总负责接收,然后叫醒某个等待中的线程,并把具体的处理过程交给它。Worker线程读入HTTP请求的URI,查找已有的object,如果命中则直接返回并回复用户。如果没有命中,则需要将所请求的内容,从后端服务器中取过来,存到缓存中,然后再回复。
    5.分配缓存的过程是这样的:它根据所读到object的大小,创建相应大小的缓存文件。为了读写方便,程序会把每个object的大小变为最接近其大小的内存页面倍数。然后从现有的空闲存储结构体中查找,找到最合适的大小的空闲存储块,分配给它。如果空闲块没有用完,就把多余的内存另外组成一个空闲存储块,挂到管理结构体上。如果缓存已满,就根据LRU机制,把最旧的object释放掉。
    6.释放缓存的过程是这样的:有一个超时线程,检测缓存中所有object的生存期,如果超初设定的TTL(Time To Live)没有被访问,就删除之,并且释放相应的结构体及存储内存。注意释放时会检查该存储内存块前面或后面的空闲内存块,如果前面或后面的空闲内存和该释放内存是连续的,就将它们合并成更大一块内存。
    7.整个文件缓存的管理,没有考虑文件与内存的关系,实际上是将所有的object都考虑是在内存中,如果系统内存不足,系统会自动将其换到swap空间,而不需要varnish程序去控制。

二.CDN简介

  • CDN是什么?
    CDN的全称是Content Delivery Network,即内容分发网络。CDN是构建在网络之上的内容分发网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能模块,使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。CDN的关键技术主要有内容存储和分发技术。
  • 基本思路:
    基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快、更稳定。通过在网络各处放置节点服务器所构成的在现有的互联网基础之上的一层智能虚拟网络,CDN系统能够实时地根据网络流量和各节点的连接、负载状况以及到用户的距离和响应时间等综合信息将用户的请求重新导向离用户最近的服务节点上。其目的是使用户可就近取得所需内容,解决 Internet网络拥挤的状况,提高用户访问网站的响应速度。
  • 服务模式:
    1.内容分发网络(CDN)是一种新型网络构建方式,它是为能在传统的IP网发布宽带丰富媒体而特别优化的网络覆盖层;而从广义的角度,CDN代表了一种基于质量与秩序的网络服务模式。
    2.简单地说,内容分发网络(CDN)是一个经策略性部署的整体系统,包括分布式存储、负载均衡、网络请求的重定向和内容管理4个要件,而内容管理和全局的网络流量管理(Traffic Management)是CDN的核心所在。通过用户就近性和服务器负载的判断,CDN确保内容以一种极为高效的方式为用户的请求提供服务。
    3.总的来说,内容服务基于缓存服务器,也称作代理缓存(Surrogate),它位于网络的边缘,距用户仅有"一跳"(Single Hop)之遥。同时,代理缓存是内容提供商源服务器(通常位于CDN服务提供商的数据中心)的一个透明镜像。这样的架构使得CDN服务提供商能够代表他们客户,即内容供应商,向最终用户提供尽可能好的体验,而这些用户是不能容忍请求响应时间有任何延迟的。

三.实验环境及其搭建

实验环境:
主机名 IP 服务
server1 172.25.4.1 varnish
server2 172.25.4.2 apache
实验环境的搭建:
  • 官网下载rhel6.5镜像,最小化安装(用不到图形界面)一个6.5版本的虚拟机
  • 虚拟机的相关设置
    1.配置网络
    Varnish-CDN加速的实现(单个后端服务器)
    2.配置yum源
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    3.vim /etc/hosts 设置本地域名解析
    Varnish-CDN加速的实现(单个后端服务器)
    4.cd /etc/udev/rules.d 进到该目录下删除70开头文件
    Varnish-CDN加速的实现(单个后端服务器)
    5.vim /etc/sysconfig/selinux 设置selinux为disabled模式
    Varnish-CDN加速的实现(单个后端服务器)
    6.关闭火墙(6.5版本使用的是iptables)
    Varnish-CDN加速的实现(单个后端服务器)
    7.安装需要的软件包
    Varnish-CDN加速的实现(单个后端服务器)
    8.设置完后poweroff关掉虚拟机,此虚拟机之后不会再打开,该虚拟机是用来快照的
  • 快照三台虚拟机(server1,server2,server3)并配置网络及主机名
    1.cd /var/lib/libvirt/images ##进到该目录下
    qemu-img create -f qcow2 -b rhel6.5.qcow2 server1/2/3 ##快照虚拟机
    Varnish-CDN加速的实现(单个后端服务器)
    2.连续安装三台虚拟机
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
    3.虚拟机安装完后进行网络配置,ip分别设置为172.25.4.1/2/3,并将主机名分别改为server1/2/3即可,修改完ip需要/etc/init.d/network restart重起网络
    Varnish-CDN加速的实现(单个后端服务器)

四.Varnish实现CDN加速(单个后端服务器)的部署

配置server1:
  1. 从官网下载varnish-3.0.5-1.el6.x86_64.rpm 和 varnish-libs-3.0.5-1.el6.x86_64.rpm两个软件包
  2. 安装这两个软件包
    Varnish-CDN加速的实现(单个后端服务器)
  3. poweroff关掉server1,将memory改为2048
    Varnish-CDN加速的实现(单个后端服务器)
    修改完后再次ssh连接,sysctl -a | grep file查看是否修改成功
    Varnish-CDN加速的实现(单个后端服务器)
  4. 修改varnish配置文件,将端口改为80
    vim /etc/sysconfig/varnish
    Varnish-CDN加速的实现(单个后端服务器)
  5. 修改varnish用户安全配置文件
    vim /etc/security/limits.conf 在最后写入如下内容
    Varnish-CDN加速的实现(单个后端服务器)
    注意:因为varnish这个程序运行在varnish这个用户的私有空间内,内核对普通用户限制的最大文件数为1024.对varnish用户限制的最大文件数为131072,我们需要满足131072这个最大值。所以在之前我们要将server1的memory改为2048
  6. 修改varnish默认文件,配置单个后端服务器
    vim /etc/varnish/default.vcl
    Varnish-CDN加速的实现(单个后端服务器)
  7. 修改完配置文件后/etc/init.d/varnish restart开启varnish服务即可
    Varnish-CDN加速的实现(单个后端服务器)
  8. 开起后 ps aux | grep varnish 查看进程是否在运行
    Varnish-CDN加速的实现(单个后端服务器)
配置server2
  1. 下载http服务
    Varnish-CDN加速的实现(单个后端服务器)
  2. 进到http默认发布目录下编写文件
    Varnish-CDN加速的实现(单个后端服务器)
    Varnish-CDN加速的实现(单个后端服务器)
  3. 编写完后/etc/init.d/httpd start 开启服务即可
    Varnish-CDN加速的实现(单个后端服务器)
客户大测试:

在真机上curl 172.25.4.1,访问的是server2主机http服务默认发布文件的内容
Varnish-CDN加速的实现(单个后端服务器)

五.清除缓存

配置server1
  1. 编辑varnish默认配置文件
    vim /etc/varnish/default.vcl ,写入如下内容
    Varnish-CDN加速的实现(单个后端服务器) 2. /etc/init.d/varnish reload,重新加载配置文件
    Varnish-CDN加速的实现(单个后端服务器)
客户端测试:
  1. 真机上curl -I 172.25.4.1访问时,第一次访问时是MISS,第二次访问时是HIT,因为第一次访问后已经缓存到了

    第一次访问:
    Varnish-CDN加速的实现(单个后端服务器)
    第二次访问:
    Varnish-CDN加速的实现(单个后端服务器)

清除缓存:
varnishadm ban.url .*$           ##清除所有缓存
varnishadm ban.url /index.html   ##清除网页的缓存

清除缓存后再次测试,显示为MISS,则清除缓存成功
Varnish-CDN加速的实现(单个后端服务器)
Varnish-CDN加速的实现(单个后端服务器)


推荐阅读
  • 雨林木风 GHOST XP SP3 经典珍藏版 V2017.11
    雨林木风 GHOST XP SP3 经典珍藏版 V2017.11 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 解决TensorFlow CPU版本安装中的依赖问题
    本文记录了在安装CPU版本的TensorFlow过程中遇到的依赖问题及解决方案,特别是numpy版本不匹配和动态链接库(DLL)错误。通过详细的步骤说明和专业建议,帮助读者顺利安装并使用TensorFlow。 ... [详细]
  • 深入解析Serverless架构模式
    本文将详细介绍Serverless架构模式的核心概念、工作原理及其优势。通过对比传统架构,探讨Serverless如何简化应用开发与运维流程,并介绍当前主流的Serverless平台。 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • vivo Y5s配备了联发科Helio P65八核处理器,这款处理器采用12纳米工艺制造,具备两颗高性能Cortex-A75核心和六颗高效能Cortex-A55核心。此外,它还集成了先进的图像处理单元和语音唤醒功能,为用户提供卓越的性能体验。 ... [详细]
  • 访问一个网页的全过程
    准备:DHCPUDPIP和以太网启动主机,用一根以太网电缆连接到学校的以太网交换机,交换机又与学校的路由器相连.学校的这台路由器与一个ISP链接,此ISP(Intern ... [详细]
  • 推荐几款高效测量图片像素的工具
    本文介绍了几款适用于Web前端开发的工具,这些工具可以帮助用户在图片上绘制线条并精确测量其像素长度。对于需要进行图像处理或设计工作的开发者来说非常实用。 ... [详细]
  • 本文详细介绍了Java中实现异步调用的多种方式,包括线程创建、Future接口、CompletableFuture类以及Spring框架的@Async注解。通过代码示例和深入解析,帮助读者理解并掌握这些技术。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 在项目部署后,Node.js 进程可能会遇到不可预见的错误并崩溃。为了及时通知开发人员进行问题排查,我们可以利用 nodemailer 插件来发送邮件提醒。本文将详细介绍如何配置和使用 nodemailer 实现这一功能。 ... [详细]
  • 12月16日JavaScript变量、函数、流程、循环等***线上九期班
    12月16日JavaScript变量、函数、流程、循环等***线上九期班 ... [详细]
  • 本文详细介绍如何在 iOS 7 环境下申请苹果开发者账号,涵盖从访问开发者网站到最终激活账号的完整流程。包括选择个人或企业账号类型、付款方式及注意事项等。 ... [详细]
author-avatar
mobiledu2502904157
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有