Varnish

Varnish是一款高性能的开源HTTP加速器,可以实现缓存和代理功能。
varnish的每个版本的功能功能有很大的变化,我们这里使用varnish4.0.4的版本。
主要的配置文件有两个:
/etc/varnish/varnish.params文件用来配置服务本身的一些参数,而/etc/varnish/目录下的defalut.vcl文件用来配置缓存的运作方式。

服务配置

我们先来看/etc/varnish/varnish.params文件配置:

  • VARNISH_VCL_CONF=/etc/varnish/default.vcl 表示使用的vcl配置文件
  • # VARNISH_LISTEN_ADDRESS=192.168.1.5
    VARNISH_LISTEN_PORT=6081
    这两项表示服务监听的地址和端口,第一项默认是禁用的,表示监听所有地址,使用默认6081端口的话,访问时需要加上指定端口号
  • VARNISH_ADMIN_LISTEN_ADDRESS=127.0.0.1
    VARNISH_ADMIN_LISTEN_PORT=6082
    这两项表示varnish的管理接口的监听地址和端口
  • VARNISH_SECRET_FILE=/etc/varnish/secre
    表示使用管理接口时候需要的认证文件
  • VARNISH_STORAGE="malloc,256M"
    使用哪种缓存存放方式,存储机制有三种,分别为:
    (1)malloc[,size],内存存储,size指定空间的大小
    (2)file[,path[,size[,granularity]]],磁盘存储,后边可以跟path路径,size大小,间隔granularity
    (3)persistent,path,size 这个也是磁盘存储,不过还处于实验阶段
  • VARNISH_USER=varnish
    VARNISH_GROUP=varnish
    这两项表示varnish使用的用户和组
  • DAEMON_OPTS="-p thread_pool_min=5 -p thread_pool_max=500 -p t
    hread_pool_timeout=300"
    这一项表示运行时状态设定,写在DAEMON_OPTS之后,每个选项使用-p隔开
vcl

defalut.vcl文件用来配置缓存的运作方式,配置完成后可以用varnish_reload_vcl来重载配置。
下面来看defalut.vcl文件的配置:
VCL有多个状态引擎,状态之间存在相关性,但状态引擎彼此间互相隔离;每个状态引擎可使用return(x)指明关联至哪个下一级引擎;每个状态引擎对应于vcl文件中的一个配置段,即为subroutine

实验

我们来实现两个lamp部署wordpress,用Nginx反代,压测以下。然后nginx之后部署varnish缓存,再次压测,然后对比没有varnish的情况。
1.环境:

  • 客户端主机:centos6.9,ip为172.16.200.101
  • nginx代理服务器:centos6.9,ip地址为172.16.200.102
  • varnish服务器:centos7.3,varnish版本为4.04,ip地址为172.16.200.106
  • 后端lamp服务器:centos6.9,两台的ip地址分别为172.16.200.103和172.16.200.104,nmp都用yum安装
  • nfs服务器:centos6.9,ip地址为172.16.200.105,安装wordpress
    2.在nginx代理服务器上安装nginx,然后修改配置文件:
[root@localhost conf.d]# yum -y install nginx
[root@localhost conf.d]# vim /etc/nginx/nginx.conf
在http上下文中添加如下内容:
        upstream web {
                server 172.16.200.103;
                server 172.16.200.104;
}
[root@localhost conf.d]# vim /etc/nginx/conf.d/var.conf    #新建这个配置文件,添加如下内容
server {
        listen 80 default;
        server_name www.feng.com;
        location / {
                proxy_pass http://172.16.200.106:6081;
        }
}
[root@localhost conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@localhost conf.d]# service nginx start

3.设置nfs服务器

[root@localhost ~]# yum -y install nfs-utils wordpress
[root@localhost ~]# vim /etc/exports
添加如下内容
/usr/share/wordpress/ 172.16.200.103(rw,no_root_squash) 172.16.200.104(rw,no_root_squash)    #no_root_squash表示不压缩权限,在本地使用时权限仍然为root,不写这一条可能导致本地不能创建文件。
[root@localhost ~]# service rpcbind start
[root@localhost ~]# service nfs start
[root@localhost ~]# exportfs -v    #检测共享成功
[root@localhost ~]# exportfs -v
/usr/share/wordpress
        172.16.200.103(rw,wdelay,no_root_squash,no_subtree_check,sec=sys,rw,no_root_squash,no_all_squash)
/usr/share/wordpress
        172.16.200.104(rw,wdelay,no_root_squash,no_subtree_check,sec=sys,rw,no_root_squash,no_all_squash)

4.两台后端lamp服务器上执行如下操作:
(1)配置php和httpd

[root@localhost ~]# yum -y install httpd php mysql-server php-mysql
[root@localhost ~]# vim /var/www/html/index.php
<?php
phpinfo();
?>

用浏览器访问http://172.16.200.103/index.php ,出现php页面证明php和httpd安装成功
(2)挂载nfs文件系统:

[root@localhost ~]# yum -y install nfs-utils
[root@localhost ~]# mkdir /var/www/html/wordpress/
[root@localhost ~]# mount 172.16.200.105:/usr/share/wordpress /var/www/html/wordpress/

(3)然后配置mysql

[root@localhost ~]# service mysqld start
[root@localhost ~]# mysql_secure_installation     #运行mysql初始化程序,给root设置个密码,然后删除多余的用户和库
[root@localhost ~]# mysql -u root -p    #输入密码后进入mysql
mysql> create database wordpress;    #创建专用库
mysql> grant all on wordpress.* to worduser@'172.16.%.%' identified by '123';    #创建并授权用户

(4)
完成后访问172.16.200.103/wordpress,出现wordpress设置页面,将在数据库中创建的库名和用户名密码输入,ip地址填写为当前lamp服务器的ip。然后下一步,这里会提示我们创建配置文件,我们在wordpress目录下创建这个文件,然后将内容粘贴进去:

[root@localhost wordpress]# cd /var/www/html/wordpress/
[root@localhost wordpress]# vim wp-config.php
将网页中提示的文件内容粘贴进去就行,这里就不在显示文件内容了

然后输入标题,输入网站用户名和密码,就进入到wordpress中了
(5)测试
在客户端服务器中安装httpd-tools,去测试刚才所做的集群

[root@localhost ~]# yum -y install httpd-tools
[root@localhost ~]# ab -c 10 -n 100 172.16.200.102/wordpress  ####压测,测试没有varnish时候的并发能力

(6)在nginx之后增加varnish服务器

修改/etc/nginx/conf.d/var.conf,将lication修改为varnish服务器ip地址。

 location / {
                proxy_pass http://172.16.200.106;
        }

然后到varnish服务器上安装varnish:

[root@localhost ~]# yum -y install varnish
[root@localhost ~]# cd /etc/varnish/
将varnish监听的地址更改为80端口:
[root@localhost varnish]# vim varnish.params
VARNISH_LISTEN_PORT=80     #将这里的6081更改为80端口
[root@localhost varnish]# vim default.vcl
将文件内容修改为以下内容:
import directors;
backend web1 {
    .host="172.16.200.103";
    .port="80";
}

backend web2 {
    .host="172.16.200.104";
    .port="80";
}

sub vcl_init {
        new server = directors.round_robin();
        server.add_backend(web1);
        server.add_backend(web2);
}
sub vcl_recv {
    if (req.method == "PURGE") {
        return(purge);
}
    if (req.url ~ "(?i)\.jsp$") {
    set req.backend_hint = server.backend();
    }
     if (req.http.Authorization || req.method == "POST") {
    return (pass);
  }
    if (req.http.Cookie ~ "wordpress_logged_in_") {
    return (pass);
  }

}
sub vcl_pipe {
        return (pipe);
}

sub vcl_pass {
        return (fetch);
}

sub vcl_backend_response {
 if (bereq.url ~ "\.(css|js|png|gif|jp(e?)g|swf|ico|txt|eot|svg|woff)") {
    unset beresp.http.cookie;
    set beresp.http.cache-control = "public, max-age=2700000";
  }
}

sub vcl_deliver {
}

然后启动varnish,用浏览器访问172.16.200.102/wordpress,访问到wordpress页面,证明实验成功。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,744评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,505评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,105评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,242评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,269评论 6 389
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,215评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,096评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,939评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,354评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,573评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,745评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,448评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,048评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,683评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,838评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,776评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,652评论 2 354

推荐阅读更多精彩内容