实验目的:
两个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页面,证明实验成功。
网友评论