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

Linux平台部署varnish高性能缓存服务器(1)

【本文档所介绍的内容适用于公司测试生产常见的varnish环境部署】一:varnish部署前准备:1.1相关软件以及系统,web服务系统要求:Centos6(以上)(64位)相关中间


【本文档所介绍的内容适用于公司测试/生产常见的varnish环境部署】

一:varnish部署前准备:

1.1相关软件以及系统,web服务

系统要求:Centos 6(以上) (64位)

相关中间件:varnish-4.0.2

1.2相关系统依赖包安装检查准备

1.2.1 检查系统自带nginx是否安装

rpm -qa | grep varnish

如有安装,请使用以下命令卸载相关程序 

yum remove varnish -y

1.2.2 安装编译nginx需要的依赖包

 yum install libtool ncurses-devel pcre-devel ibedit-devel pkgconfig python-docutils python-sphinx automake autoconf  -y

1.2.3 安装好相关web服务

 安装Apache,nginx,tomcat等都行,本文档的web安装在本地,使用的nginx web 端口为:8080

二:varnish 部署安装

2.1 下载varnish安装包

如有所示为varnish的官网:https://www.varnish-cache.org/releases,选择对应的varnish版本,本文档用的版本是varnish4.0.2 

cd /usr/local/srcwget https://repo.varnish-cache.org/source/varnish-4.0.2.tar.gz

2.2 编译安装varnish

cd /usr/local/srctar zxvf varnish-4.0.2.tar.gz./configure CPPFLAGS="-I$PATH_TO_LIBEDIT/include" LDFLAGS="-L$PATH_TO_LIBEDIT/lib" \--prefix=/usr/local/varnish4.0.2 make && make install

2.3 配置varnish的启动脚本

echo "/usr/local/varnish4.0.2/sbin/varnishd -P /var/run/varnish.pid -f /usr/local/varnish4.0.2/etc/default.vcl -s malloc,1G -T 127.0.0.1:2000 -a 0.0.0.0:80" > /usr/local/varnish4.0.2/sbin/varnishd.sh 

2.4 将varnish以开机服务的形式启动,并加入系统服务

2.4.1 编辑/etc/init.d/varnishd

vim /etc/init.d/varnishd

2.4.2 在/etc/init.d/varnishd添加以下内容

#!/bin/sh#chkconfig:345 85 15 #description: varnish cache server# varnish# Copyright (C) 2001-2014 varnish cache#SERVICE="varnish server"DAEMON=/usr/local/varnish4.0.2/sbin/varnishd.shPIDFILE=/var/run/varnish.pidcase $1 in  'start')    if [ -x ${DAEMON} ]    then      $DAEMON      # Error checking here would be good...      echo "${SERVICE} started success ! "    else      echo "Can't find file ${DAEMON}."      echo "${SERVICE} NOT started."    fi  ;;  'stop')    if [ -s ${PIDFILE} ]    then      if kill `cat ${PIDFILE}` >/dev/null 2>&1      then        echo "${SERVICE} shutdown success !"        rm -f ${PIDFILE}      fi    fi  ;;  'restart')    $0 stop    sleep 10    $0 start  ;;  *)    echo "Usage: $0 start|stop|restart"    ;;esac

2.4.3 编辑/usr/local/varnish4.0.2/etc/default.vcl添加以下内容

vcl 4.0;backend webserver {    .host = "127.0.0.1";    .port = "8080";         //等同于后端web server    .connect_timeout = 4s;      .first_byte_timeout = 5s;      .between_bytes_timeout = 20s;  }

2.4.4启动varnishd 服务

service varnishd start

三:varnish验证测试

启动web服务

service nginx start

使用系统自带的命令curl -I localhost 如下所示:

HTTP/1.1 200 OKServer: nginx/1.8.0Date: Mon, 04 Jan 2016 07:50:09 GMTContent-Type: text/htmlLast-Modified: Mon, 31 Aug 2015 03:55:55 GMTETag: "55e3d04b-264"X-Varnish: 112 131182Age: 80Via: 1.1 varnish-v4Content-Length: 612Connection: keep-alive

本文如上红色部分,当X-varnish 后面出现两组数据的时候,说明缓存成功,这时我们在关掉web服务,数据会从varnish缓存里读取,如下

关闭web服务

service nginx stop

重新curl -I localhost 如果命中缓存,则如下所示:

HTTP/1.1 200 OKServer: nginx/1.8.0Date: Mon, 04 Jan 2016 07:53:47 GMTContent-Type: text/htmlLast-Modified: Mon, 31 Aug 2015 03:55:55 GMTETag: "55e3d04b-264"X-Varnish: 110 131182Age: 8Via: 1.1 varnish-v4Content-Length: 612Connection: keep-alive

当没有从缓存里命中时,会出现以下提示(没有命中缓存,则X-varnish后面数字为单组数字):

HTTP/1.1 503 Backend fetch failedDate: Mon, 04 Jan 2016 07:55:59 GMTServer: VarnishContent-Type: text/html; charset=utf-8Retry-After: 5X-Varnish: 98457Age: 0Via: 1.1 varnish-v4Content-Length: 282Connection: keep-alive

至此整个varnish的部署安装基本就OK了

本文出自 “菜鸟的成长记” 博客,请务必保留此出处http://blief.blog.51cto.com/6170059/1731390


推荐阅读
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • Varnish搭建CDN内容分发网络
    概述:1.CDN内容分发网络CDN的全称是ContentDeliveryNetwork,即内容分发网络。其基本思路是尽可能避开互联网上有可能影响数据 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 本文探讨了如何通过一系列技术手段提升Spring Boot项目的并发处理能力,解决生产环境中因慢请求导致的系统性能下降问题。 ... [详细]
  • 本文档汇总了Python编程的基础与高级面试题目,涵盖语言特性、数据结构、算法以及Web开发等多个方面,旨在帮助开发者全面掌握Python核心知识。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 作为140字符的开创者,Twitter看似简单却异常复杂。其简洁之处在于仅用140个字符就能实现信息的高效传播,甚至在多次全球性事件中超越传统媒体的速度。然而,为了支持2亿用户的高效使用,其背后的技术架构和系统设计则极为复杂,涉及高并发处理、数据存储和实时传输等多个技术挑战。 ... [详细]
  • varnish2.04配置文章来源:http:blog.163.comkoumm126blogstatic9540383720091182424317修改varnishheader ... [详细]
  • redis理论知识redis:非关系型数据库基于键值对的形式存储数据的查询效率非常的高没有表之间的约束查询起来比较方便redis特点:1.支持多种数据类型2.支持分布式存储3.功能 ... [详细]
  • 怎么查看linux日志里请求量最高的url访问最多的_40道Linux运维面试精华题,请收下这份跳槽秘籍!...
    过一次年,结婚、存款、父母养老,一系列向钱看的事都在碾压我们本来还挺简单的神经,但难过没有出路,唯有找到好的方法和事业方向& ... [详细]
  • varnish 测试
    安装通过epel源yum安装[rootlocalhostvarnish]#rpm-qlvarnishetclogrotate.dvarnishetcvarnishetcvar ... [详细]
  • 离线安装Grafana Cloudera Manager插件并监控CDH集群
    本文详细介绍如何离线安装Cloudera Manager (CM) 插件,并通过Grafana监控CDH集群的健康状况和资源使用情况。该插件利用CM提供的API接口进行数据获取和展示。 ... [详细]
author-avatar
有一颗爱心和寂寞的心
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有