美文网首页
varnish实验

varnish实验

作者: geekdeedy | 来源:发表于2017-09-11 08:25 被阅读0次

实验目的:

两个lamp部署wordpress,用Nginx反代,压测以下。然后nginx之后部署varnish缓存,再次压测,然后对比没有varnish的情况。

实验环境:

一共7台主机
1台作为客户端主机、1台nginx代理服务器、1台作为varnish服务器、2台作为后端lamp服务器、1台作为nfs服务器安装wordpress

实验过程

2.在nginx代理服务器上安装nginx,然后修改配置文件:
yum install nginx
vim /etc/nginx/nginx.conf
在http上下文中添加如下内容:

        upstream web {
                server 172.16.10.4:80;
                server 172.16.10.5:80;
}
vim /etc/nginx/conf.d/var.conf    #新建这个配置文件,添加如下内容
server {
        listen 80 default;
        server_name test.io;
        location / {
                proxy_pass http://172.16.10.3:6081;
        }
}

nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
systemctl start nfs

3.设置nfs服务器

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

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

yum -y install httpd php mysql-server php-mysql
vim /var/www/html/index.php
<?php
phpinfo();
?>

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

yum -y install nfs-utils
mkdir /var/www/html/wordpress/
mount 172.16.200.105:/usr/share/wordpress /var/www/html/wordpress/

(3)然后配置mysql

service mysqld start
mysql_secure_installation #运行mysql初始化程序,给root设置个密码,然后删除多余的用户和库
mysql -u root -p #输入密码后进入mysql
mysql> create database wordpress; #创建专用库
mysql> grant all on wordpress.* to worduser@'172.16.%.%' identified by '123'; #创建并授权用户
(4)
完成后访问172.16.10.4/wordpress,出现wordpress设置页面,将在数据库中创建的库名和用户名密码输入,ip地址填写为当前lamp服务器的ip。然后下一步,这里会提示我们创建配置文件,我们在wordpress目录下创建这个文件,然后将内容粘贴进去:

cd /var/www/html/wordpress/
vim wp-config.php
将网页中提示的文件内容粘贴进去就行,这里就不在显示文件内容了
然后输入标题,输入网站用户名和密码,就进入到wordpress中了
(5)测试
在客户端服务器中安装httpd-tools,去测试刚才所做的集群

yum -y install httpd-tools
ab -c 10 -n 100 172.16.10.2/wordpress ####压测,测试没有varnish时候的并发能力
(6)在nginx之后增加varnish服务器

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

 location / {
                proxy_pass http://172.16.10.3;
        }

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

yum -y install varnish
cd /etc/varnish/
将varnish监听的地址更改为80端口:
vim varnish.params
VARNISH_LISTEN_PORT=80 #将这里的6081更改为80端口
vim default.vcl
将文件内容修改为以下内容:

import directors;
backend web1 {
    .host="172.16.10.4";
    .port="80";
}

backend web2 {
    .host="172.16.10.5";
    .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.10.2/wordpress,如果访问到wordpress页面,证明实验成功。

相关文章

网友评论

      本文标题:varnish实验

      本文链接:https://www.haomeiwen.com/subject/tcexsxtx.html