lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress)

lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress)

 

lvs实践(lvs+nginx+mariadb+php—fpm+nfs搭建wordpress)

lvs_dr模型 nginx mariadb php-fpm wordpress


 

 

实验拓扑

lvs项目.jpg-155.4kB

要求说明:
    1、lvs——director调度两台nginx+php-fpm real server 采用dr模型 算法为rr
    2、mriadb为real server提供数据库 nfs挂载至2台real-server提供文件服务
    3、为了方便起见各节点iptables和selinux均已关闭。
    4、windows本地提供host文件做解析z.com至

step1:网络配置

按照拓扑图要求配置网络环境。

step2:各节点软件安装

lvs——director:

 #yum -y install ipvsadm

两台real server:

# yum -y install nginx nfs-utils rpcbind
# yum -y install php-fpm php-mysql php-gd php-mbstring php-mcrypt

nfs-server:

# yum -y install nfs-utils rpcbind

Mariadb-server

#yum -y install mariadb*

step3:服务配置

nfs_server配置

#groupadd www -g 501
#useradd www -u 501 -g www -M -r  
#mkdir /usr/share/nginx/html/
#chown -R www:www /usr/share/nginx/html/
# echo '/usr/share   192.168.3.0/24(rw,sync,all_squash,anongid=501,anonuid=501)' > /etc/exports
#exportfs -rv
#systemctl start rpcbind.service 
#systemctl start nfs.service 
#cd /usr/share/nginx/html/
#准备好wordpress
#wget https://cn.wordpress.org/wordpress-4.5.2-zh_CN.tar.gz
# tar zxvf wordpress-4.5.2-zh_CN.tar.gz
# cp -R wordpress/* ./
# cp wp-config-sample.php wp-config-sample.php.bak
# mv wp-config-sample.php wp-config.php
#修改如下 部分略
#<?php
/**
 * WordPress基础配置文件。
 *
 * 这个文件被安装程序用于自动生成wp-config.php配置文件,
 * 您可以不使用网站,您需要手动复制这个文件,
 * 并重命名为“wp-config.php”,然后填入相关信息。
 *
 * 本文件包含以下配置选项:
 *
 * * MySQL设置
 * * 密钥
 * * 数据库表名前缀
 * * ABSPATH
 *
 * @link https://codex.wordpress.org/zh-cn:%E7%BC%96%E8%BE%91_wp-config.php
 *
 * @package WordPress
 */

// ** MySQL 设置 - 具体信息来自您正在使用的主机 ** //
/** WordPress数据库的名称 */
define('DB_NAME', 'wordpress');

/** MySQL数据库用户名 */
define('DB_USER', 'wordpress');

/** MySQL数据库密码 */
define('DB_PASSWORD', '123456');

/** MySQL主机 */
define('DB_HOST', '192.168.3.8');

lvs—director

#ifconfig eno16777736:0 192.168.2.11/32 broadcast 192.168.2.11 up
#route add -host 192.168.2.11 dev eno16777736:0

两台real—server

#echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
#echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
#echo 1 > /proc/sys/net/ipv4/conf/eno16777736/arp_ignore
# echo 2 > /proc/sys/net/ipv4/conf/eno16777736/arp_announce
#ifconfig lo:0 192.168.2.11/32 broadcast 192.168.2.11 up
#route add -host 192.168.2.11 dev lo:0
#systemctl start rpcbind.service
#mount -t nfs 192.168.3.9:/usr/share/ /usr/share/nginx
# df -h

文件系统                      容量  已用  可用 已用% 挂载点
/dev/mapper/centos-root        18G  1.4G   17G    8% /
devtmpfs                      105M     0  105M    0% /dev
tmpfs                         115M     0  115M    0% /dev/shm
tmpfs                         115M  8.6M  107M    8% /run
tmpfs                         115M     0  115M    0% /sys/fs/cgroup
/dev/sda1                     497M  124M  373M   25% /boot
tmpfs                          23M     0   23M    0% /run/user/0
192.168.3.9:/usr/share/nginx   18G  1.1G   17G    7% /usr/share/nginx
# vim /etc/nginx/conf.d/z.com.conf

server {
    listen          80;
    server_name     z.com;
    root            /htdocs/z_com;
    index           index.php;
    add_header X-via $server_addr;

    location / {
            root    /htdocs/z_com;
            index   index.php index.html index.html;
    }

    location ~* \.(jpg|jpeg|png|gif|js|css)$ {
            root    /htdocs/z_com;
    }

    location ~ \.php$ {
            root            /htdocs/z_com;
            fastcgi_pass    127.0.0.1:9000;
            fastcgi_index   index.php;
            fastcgi_param   SCRIPT_FILENAME /htdocs/z_com$fastcgi_script_name;
            include         fastcgi_params;
    }
}
#systemctl start nginx.service

Mariadb数据库配置

#systemctl start mariadb.service
#mysql
MariaDB [(none)]> create database wordpress;
grant all on wordpress.* to 'wordpress'@'%' identified by '123456';

step4:lvsdirector集群配置

#ipvsadm -A -t 192.168.2.11:80 -s rr
#ipvsadm -a -t 192.168.2.11:80 -r 192.168.2.117 -g
#ipvsadm -a -t 192.168.2.11:80 -r 192.168.2.135 -g
# ipvsadm -Ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.2.11:80 rr
  -> 192.168.2.117:80             Route   1      0          0         
  -> 192.168.2.135:80             Route   1      0          0

最后效果如下
QQ图片20161214002614.png-80.1kB
QQ图片20161214100207.png-108.1kB
QQ图片20161214121852.png-47.2kB

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

(0)
Net17_desperadoNet17_desperado
上一篇 2017-01-03 11:05
下一篇 2017-01-03 11:05

相关推荐

  • LVM管理

    LVM管理

    2017-12-28
  • 对防火墙的初步认识

      防火墙,就是用于实现Linux下访问控制的功能的,它分为硬件的或者软件的防火墙两种。无论是在哪个网络中,防火墙工作的地方一定是在网络的边缘。而我们的任务就是需要去定义到底防火墙如何工作,这就是防火墙的策略,规则,以达到让它对出入网络的IP、数据进行检测。    目前市面上比较常见的有3、4层的防火墙,叫网络层的防火墙,还有7…

    Linux干货 2017-06-15
  • 在虚拟机上使用CentOS6的两个iso文件创建本地yum仓库和http仓库

    yum客户端和服务器端都是本虚拟机 一、创建本地磁盘访问的yum仓库 条件和要求: a.guest虚拟机需要添加2个光驱,分别装载CentOS6.4发行版的DVD1和DVD2 b.DVD1和DVD2的挂载目录分别是:/media/cdrom/下的os和extras,并设置开机挂载 c.使用CentOS-Media.repo作为yum客户端配置文件,将其他re…

    Linux干货 2015-09-22
  • 马哥教育网络班22期+第八周课程练习

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。    网桥:工作在OSI模型的数据链路层,将两个局域网连起来,根据MAC地址来转发帧,可以看作是一个“低层的路由器”(路由器工作在OSI模型的网络层,根据网络地址如IP地址进行转发)。它可以有效地联接两个LAN,使本地通信限制在本网段内,并…

    Linux干货 2016-11-17
  • 马哥linux课堂笔记

    0805课堂笔记 基本权限 读,写,执行   对于文件的读权限,能否查看文件内容.(文件内容需不需要看,如果是文本就需要看,如果是二进制就不需要看) 对于文件的写权限,能否修改文件内容,不能修改文件名,不能删除文件.(如果需要修改文件内容和文件名,必须在其父目录增加写权限和执行权限) 对于文件的执行权限,能否运行他.   对于目录的读权限…

    Linux干货 2016-08-15
  • 马哥教育网络班21期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -d' ' -f1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 [ro…

    Linux干货 2016-07-29