lvs负载集群实验(实现wordpress)

lvs负载集群实验(实现wordpress)

项目要求:

(1) lvs 调度两台 nginx+php-fpmreal-server,采用 dr 模型,调度算法为 rr

(2) mariadb real-server 提供数据库,nfs 挂载至 2 real-server 提供文件服务

(3) 由于实验环境地址冲突将VIP替换为172.18.60.60

实施步骤:

一、配置NFS+mariadb-server

1、使用yum安装相关软件

[root@localhost
~]# yum install -y nfs-utils rpcbind mysql-server nginx

2、启动数据库,配置数据库,创建数据库和授权用户,并退出

[root@localhost
~]# service start mysqld

[root@localhost
~]# mysql

mysql>
create database wpdb;

Query
OK, 1 row affected (0.00 sec)

mysql>
grant all on wpdb.* to ‘wpuser’@’172.18.%’ identified by ‘wppass’;

Query
OK, 0 rows affected (0.00 sec)

mysql>
exit

Bye

3、创建data目录,下载wordpress安装包并解压,并且赋予wordpress文件夹属主属组

[root@localhost
~]# mkdir /data/

[root@localhost
~]# cd /data/

wget
ftp://172.18.0.1/pub/Sources/sources/httpd/wordpress-4.3.1-zh_CN.zip

[root@localhost
~]#unzip wordpress-4.3.1-zh_CN.zip

[root@localhost
data]# chown -R nginx.nginx /data/wordpress

[root@localhost
data]# ll

drwxr-xr-x
5 nginx nginx    4096 Sep 16  2015 wordpress

-rw-r–r–
1 root  root  7518362 May 
9 20:59 wordpress-4.3.1-zh_CN.zip

4、设置文件夹共享

[root@localhost
data]# vim /etc/exports

/data/wordpress
172.18.10.1[01](rw)

 

5、启动nfs服务,注意,必须优先启动rpcbind服务,才能成功启动nfs服务,不然报错。

[root@localhost
data]# service rpcbind start

Starting
rpcbind:                                         
[  OK  ]

[root@localhost
data]# service nfs start

Starting
NFS services:                                     [  OK  ]

Starting
NFS quotas:                                       [  OK  ]

Starting
NFS mountd:                                       [  OK  ]

Starting
NFS daemon:                                       [  OK  ]

Starting
RPC idmapd:                                       [  OK  ]

6、查看共享的文件服务

[root@localhost
data]# showmount -e 172.18.249.57

Export
list for 172.18.249.57:

/data/wordpress
172.18.10.1[01]

成功共享

二、配置Nginx+php-fpm server1

1、 使用yum安装相关服务

[root@localhost
~]# yum install -y nginx php-fpm php-mysql nfs-utils

2、 创建文件路径wordpress目录

[root@localhost
~]# mkdir -pv /data/wordpress

3、 启动nginx服务,并编辑相关配置文件wdps.conf

[root@localhost
~]# vim /etc/nginx/conf.d/wdps.conf

server
{

        listen          80 default_server;

        server_name     www.magedu.com;

        root            /data/wordpress/;

        index           index.php index.html index.htm;

        location / {

        }

 

        location ~ \.php$ {

                fastcgi_pass 127.0.0.1:9000;

                fastcgi_index index.php;

                fastcgi_param SCRIPT_FILENAME
/data/wordpress/$fastcgi_script_name;

                include fastcgi_params;

        }

}

[root@localhost
conf.d]# scp wdps.conf 172.18.10.11:/etc/nginx/conf.d/wdps.conf

[root@localhost
conf.d]# vim default.conf

删除 default_server字段

4、 启动nginx

[root@localhost
conf.d]# nginx

[root@localhost
conf.d]# ss –tnl

5、 启动php-fpm服务

[root@localhost
~]# service php-fpm start

Starting
php-fpm:                                          [ 
OK  ]

6、 将后端共享的wordpress文件夹挂载

[root@localhost
data]# mount -t nfs 172.18.249.57:/data/wordpress /data/wordpress

7、 编写lvs-dr脚本

[root@localhost
~]# vim dr.sh

#!/bin/bash

VIP=172.18.50.50

case
“$1” in

start)

        echo “配置 lvsRealServer 开始…”

        ifconfig lo:0 $VIP broadcast $VIP
netmask 255.255.255.255 up  ##
配置 VIP

        route add -host $VIP dev lo:0  ## 添加主机路由

        ## 限制响应和通告级别

        echo “1” >
/proc/sys/net/ipv4/conf/lo/arp_ignore

        echo “1” >
/proc/sys/net/ipv4/conf/all/arp_ignore

        echo “2” >
/proc/sys/net/ipv4/conf/lo/arp_announce

        echo “2” >
/proc/sys/net/ipv4/conf/all/arp_announce

        ;;

stop)

        echo “正在关闭 lvsRealserver”

        ifconfiglo:0down

        echo “0” >
/proc/sys/net/ipv4/conf/lo/arp_ignore

        echo “0” >
/proc/sys/net/ipv4/conf/all/arp_ignore

        echo “0” >
/proc/sys/net/ipv4/conf/lo/arp_announce

        echo “0” >
/proc/sys/net/ipv4/conf/all/arp_announce

        ;;

*)

        echo “用法:$0{start|stop}”

        exit 1

esac

[root@localhost
~]# bash dr.sh start

配置 lvsRealServer 开始

[root@localhost
~]# scp dr.sh 172.18.10.11:/root/

[root@localhost
~]# ip a

1:
lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

    link/loopback 00:00:00:00:00:00 brd
00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

    inet 172.18.50.50/32 brd 172.18.50.50 scope
global lo:0

    inet6 ::1/128 scope host

       valid_lft forever preferred_lft forever

2:
eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state
UP qlen 1000

    link/ether 00:0c:29:07:27:ff brd
ff:ff:ff:ff:ff:ff

    inet 172.18.10.10/16 brd 172.18.255.255
scope global eth1

    inet6 fe80::20c:29ff:fe07:27ff/64 scope
link

       valid_lft forever preferred_lft forever

三、配置Nginx+php-fpm server2

8、 使用yum安装相关服务

[root@localhost
~]# yum install -y nginx php-fpm php-mysql nfs-utils

9、 创建文件路径wordpress目录

[root@localhost
~]# mkdir -pv /data/wordpress

10、              启动nginx服务,并编辑相关配置文件wdps.conf

[root@localhost
~]# vim /etc/nginx/conf.d/wdps.conf

server
{

        listen          80 default_server;

        server_name     www.magedu.com;

        root            /data/wordpress/;

        index           index.php index.html index.htm;

        location / {

        }

 

        location ~ \.php$ {

                fastcgi_pass 127.0.0.1:9000;

                fastcgi_index index.php;

                fastcgi_param SCRIPT_FILENAME
/data/wordpress/$fastcgi_script_name;

                include fastcgi_params;

        }

}

[root@localhost
conf.d]# scp wdps.conf 172.18.10.11:/etc/nginx/conf.d/wdps.conf

[root@localhost
conf.d]# vim default.conf

删除 default_server字段

11、              启动nginx

[root@localhost
conf.d]# nginx

[root@localhost
conf.d]# ss –tnl

12、              启动php-fpm服务

[root@localhost
~]# service php-fpm start

Starting
php-fpm:                                          [  OK  ]

13、              将后端共享的wordpress文件夹挂载

[root@localhost
data]# mount -t nfs 172.18.249.57:/data/wordpress /data/wordpress

14、              编写lvs-dr脚本

[root@localhost
~]# vim dr.sh

#!/bin/bash

VIP=172.18.50.50

case
“$1” in

start)

        echo “配置 lvsRealServer 开始…”

        ifconfig lo:0 $VIP broadcast $VIP
netmask 255.255.255.255 up  ##
配置 VIP

        route add -host $VIP dev lo:0  ## 添加主机路由

        ## 限制响应和通告级别

        echo “1” >
/proc/sys/net/ipv4/conf/lo/arp_ignore

        echo “1” >
/proc/sys/net/ipv4/conf/all/arp_ignore

        echo “2” >
/proc/sys/net/ipv4/conf/lo/arp_announce

        echo “2” >
/proc/sys/net/ipv4/conf/all/arp_announce

        ;;

stop)

        echo “正在关闭 lvsRealserver”

        ifconfiglo:0down

        echo “0” >
/proc/sys/net/ipv4/conf/lo/arp_ignore

        echo “0” >
/proc/sys/net/ipv4/conf/all/arp_ignore

        echo “0” >
/proc/sys/net/ipv4/conf/lo/arp_announce

        echo “0” >
/proc/sys/net/ipv4/conf/all/arp_announce

        ;;

*)

        echo “用法:$0{start|stop}”

        exit 1

esac

[root@localhost
~]# bash dr.sh start

配置 lvsRealServer 开始

[root@localhost
~]# scp dr.sh 172.18.10.11:/root/

[root@localhost
~]# ip a

1:
lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

    link/loopback 00:00:00:00:00:00 brd
00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

    inet 172.18.50.50/32 brd 172.18.50.50 scope
global lo:0

    inet6 ::1/128 scope host

       valid_lft forever preferred_lft forever

2:
eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state
UP qlen 1000

    link/ether 00:0c:29:07:27:ff brd
ff:ff:ff:ff:ff:ff

    inet 172.18.10.10/16 brd 172.18.255.255
scope global eth1

    inet6 fe80::20c:29ff:fe07:27ff/64 scope
link

       valid_lft forever preferred_lft forever

四、配置LVS-server

1、 安装ipvsadm

[root@localhost
~]# yum install ipvsadm

2、 添加网卡别名,并查看

[root@localhost
~]# ip addr add 172.18.50.50/32 dev eth1

[root@localhost
~]# ip a

1:
lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

    link/loopback 00:00:00:00:00:00 brd
00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

    inet6 ::1/128 scope host

       valid_lft forever preferred_lft forever

2:
eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state
UP qlen 1000

    link/ether 00:0c:29:23:f3:8d brd
ff:ff:ff:ff:ff:ff

    inet 172.18.200.100/16 brd 172.18.255.255
scope global eth1

    inet 172.18.50.50/16 scope global secondary
eth1

    inet6 fe80::20c:29ff:fe23:f38d/64 scope
link

       valid_lft forever preferred_lft forever

3、 配置负载均衡

[root@localhost
~]# ipvsadm -A -t 172.18.50.50:80 -s rr ##
新增集群服务,使用rr轮巡模式

4、为集群添加real-server

[root@localhost
~]# ipvsadm -a -t 172.18.50.50:80 -r 172.18.10.10:80 -g

[root@localhost
~]# ipvsadm -a -t 172.18.50.50:80 -r 172.18.10.11:80 –g

5、查看集群规则

[root@localhost
~]# ipvsadm -Ln

IP
Virtual Server version 1.2.1 (size=4096)

Prot
LocalAddress:Port Scheduler Flags

  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn

TCP  172.18.50.50:80 rr

  -> 172.18.10.10:80              Route   1     
0          0        

  -> 172.18.10.11:80              Route   1     
0          0 

 

 

打开浏览器,输出172.18.50.50

成功访问

lvs负载集群实验(实现wordpress)lvs负载集群实验(实现wordpress)lvs负载集群实验(实现wordpress)lvs负载集群实验(实现wordpress)

原创文章,作者:oranix,如若转载,请注明出处:http://www.178linux.com/75156

(0)
oranixoranix
上一篇 2017-05-09 22:47
下一篇 2017-05-11 09:53

相关推荐

  • DNS服务器类型及查询过程

    什么是DNS   DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。 DNS域名称   域名系统作为一个层次结构和分布式数据库,包含各种类型的数据,…

    Linux干货 2017-02-08
  • Linux中的cut、sort、uniq以及用户(组)管理类指令应用示例

    Linux中的cut、sort、uniq指令 列出当前系统上所有已经登录的用户的用户名,注意:同一用户登录多次,只显示一次。 解决思路: 先使用who指令显示出所有已登录的用户。然后对who指令的输出进行切割得到想要的第一列内容,即只包含用户名。可以使用cut指令。最后对cut的结果进行排序并去重。可以使用sort指令。   借助管道符,可以方便的…

    Linux干货 2016-11-13
  • Cacti整合Zabbix监控

    前言: 由于公司现在很多业务都是使用cacti进行监控流量的,并且还有一些使用zabbix监控的项目,正好又有一个项目需要搭建Cacti+Zabbix进行综合监控,搭建完毕之后发现,Cacti较之以前有了不小的改进,所以就来写一写Cacti和Zabbix监控整合的文章,顺便说一下Cacti下的一些好用的插件。 环境: Centos 6.4 X86_64 Ca…

    Linux干货 2015-03-19
  • N25-第13周博客作业

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)   1)共享名为shared,工作组为magedu;   2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名; &n…

    Linux干货 2017-05-21
  • 马哥M20-1第一周作业

    作业1:通过echo实现字体闪烁,添加下划线,改变颜色      (1)添加下划线    (2)字体闪烁   (3)改变颜色 作业2:显示前10天的年月日 作业3:screen的使用

    Linux干货 2016-07-29
  • N22-南京-修 第一周作业

    一、计算机的组成     计算机由硬件系统和软件系统组成;         硬件系统:运算器、控制器、存储器、输入设备、输出设备; (运算器、控制器):统称为CPU,它是一个具有特定功能的芯片,通过其内部含有的微指令集对从内存中读取来的数据…

    Linux干货 2016-08-15