LAMP平台基于NFS实现web服务器负载均衡

前言

随着访问量的逐渐增大,一台web服务器可能已经无法满足需求,这就需要增加web服务器的数量了,于是问题就来了:如何保证两台服务器数据同步呢?本文将讲解如何基于NFS实现web服务器的负载均衡及数据同步。

NFS服务介绍

NFS(Network File System)网络文件系统,允许一个系统通过网络共享目录和文件,通过使用NFS,用户和程序可以像访问本地文件一样访问远端系统上的文件。NFS本身没有提供数据传输的功能,必须借助于远程过程调用(RPC)协议来实现数据的传输。

配置文件

NFS在CentOS6上的配置文件及服务提供程序

程序包:nfs-utils
脚本:/etc/rc.d/init.d/nfs        
      /etc/rc.d/init.d/nfslock    
      /etc/rc.d/init.d/rpcgssd
      /etc/rc.d/init.d/rpcidmapd
      /etc/rc.d/init.d/rpcsvcgssd
配置文件:/etc/exports  
          /etc/sysconfig/nfs     #提供额外功能

配置文件详解

/etc/exports文件格式及选项

文件系统 	客户端(选项) 客户端(选项)

客户端:IP、FQDN或DOMAIN、NETWORK
选项:
secure:缺省选项,它使用了1024以下的TCP/IP端口实现NFS的连接。指定insecure可以禁用这个选项
rw:这个选项允许 NFS 客户机进行读/写访问。缺省选项是只读(ro)。
async:可改进性能,但是如果没有完全关闭NFS守护进程就重新启动了NFS服务器,也可能会造成数
据丢失,缺省为为sync
no_wdelay:关闭写延时,如果设置了async,那么NFS就会忽略这个选项
nohide:如果将一个目录挂载到另外一个目录之上,那么原来的目录通常就被隐藏起来或看起来像
空的一样,要禁用这种行为,需启用 hide 选项
no_subtree_check:关闭子树检查,子树检查会执行一些不想忽略的安全性检查,缺省选项是启用
子树检查
no_auth_nlm:可作为insecure_locks指定,它告诉 NFS 守护进程不要对加锁请求进行认证。如果
关心安全性问题,就要避免使用这个选项,缺省选项是 auth_nlm 或 secure_locks
mp (mountpoint=path): 通过显式地声明这个选项,NFS 要求挂载所导出的目录
fsid=num:通常都在 NFS 故障恢复的情况中使用。如果希望实现 NFS 的故障恢复,请参考 NFS 文档。
用户映射的选项:
root_squash:不允许root用户访问挂载上来的 NFS 卷
no_root_squash:允许 root 用户访问挂载上来的 NFS 卷
all_squash:限制所有的 UID 和 GID,只使用匿名用户,缺省设置是 no_all_squash
anonuid 和 anongid:将匿名 UID 和 GID 修改成特定用户和组帐号

相关命令

查看NFS服务器端共享的文件系统:
showmount -e NFSSERVER_IP
挂载NFS文件系统:
mount -t nfs SERVER:/path/to/sharedfs  /path/to/mount_point
exportfs:维护exports文件导出的文件系统表的专用工具
export -ar: 重新导出所有的文件系统
export -au: 关闭导出的所有文件系统
export -u FS: 关闭指定的导出的文件系统
开机自动挂载nfs
vim /etc/fstab
SERVER:/PATH/TO/EXPORTED_FS /mount_point 	nfs 	defaults,_netdev 	0 0

NFS实现web服务器负载均衡

工作原理


配置过程

案例要求:

DNS服务器:172.168.10.10(CentOS6.6)

web服务器1:172.16.10.100(CentOS6.6 )

web服务器2:172.16.10.212(CentOS6.6 )

php服务器:172.16.10.110(CentOS6.6)

NFS服务器:172.16.10.110(CentOS6.6)

数据库服务器:172.16.10.211(CentOS6.6) MariaDB

要求两台web服务器上提供同一个站点(blog.scholar.com  wordpress站点),站点目录位于NFS服务器为/web/blog,两台web服务器数据需保持统一

请确保各服务器,服务软件已安装,我这里已经安装好了(其实是借用以前的),编译安装的神马的详见博客

DNS服务器配置

修改正反向区域文件

正向解析

反向解析

检查语法,启动服务

NFS服务器配置

创建共享目录,并设置权限

编辑配置文件,设置共享目录及客户端

[[email protected] ~]# vim /etc/exports 

/web/blog       172.16.10.100(rw,sync) 172.16.10.212(rw,async)

站点文件准备

[[email protected] ~]# unzip wordpress-3.2.1-zh_CN.zip
[[email protected] ~]# cd wordpress
[[email protected] wordpress]# mv * /web/blog
[[email protected] wordpress]# cd /web/blog
[[email protected] blog]# cp wp-config-sample.php wp-config.php 
[[email protected] blog]# vim wp-config.php 
 
/** WordPress 数据库的名称 */
define(‘DB_NAME‘, ‘wpdb‘);
 
/** MySQL 数据库用户名 */
define(‘DB_USER‘, ‘wpuser‘);
 
/** MySQL 数据库密码 */
define(‘DB_PASSWORD‘, ‘wppass‘);
 
/** MySQL 主机 */
define(‘DB_HOST‘, ‘172.16.10.211‘);

启动服务,查看监听端口

数据库服务器配置

为wordpress程序提供数据库

web服务器配置

启用相关模块

[[email protected] ~]# vim /etc/httpd24/httpd.conf
 
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

启用虚拟主机

#DocumentRoot "/usr/local/apache/htdocs"   #关闭中心主机
 
Include /etc/httpd24/extra/httpd-vhosts.conf #启用虚拟主机

使之支持php

<IfModule dir_module>
    DirectoryIndex index.html index.php
</IfModule>
 
AddType application/x-httpd-php  .php
AddType application/x-httpd-php-source  .phps

配置虚拟主机

[[email protected] ~]# vim /etc/httpd24/extra/httpd-vhosts.conf 
 
<VirtualHost *:80>
    DocumentRoot "/web/blog"
    ServerName blog.scholar.com
    ProxyRequests Off            #关闭正向代理
    ProxyPassMatch ^/(.*\.php)$ fcgi://172.16.10.110:9000/web/blog/$1 #代理至php服务器
<Directory "/web/blog">
        Options none
        AllowOverride none
        Require all granted
</Directory>
</VirtualHost>

挂载共享目录

#可设置开机自动挂载
[[email protected] ~]# vim /etc/fstab 

172.16.10.110:/web/blog  /web/blog               nfs     defaults,_netdev 0 0

检查语法,启动服务

测试站点是否访问正常

可以访问的,接下来我们看一下,数据是否可以同步

指定某一台服务器IP访问

我们在这台服务器登陆,发表一篇博文

现在我们通过另外一台服务器看一下,是否可以看到刚刚发表的博文

OK,可以看到,数据同步的目的也实现了

The end

“世界那么大,我想去看看...”希望有朝一日我也可以如此洒脱...好了,基于NFS实现web服务器的负载均衡就说到这里了,遇到什么问题可留言,我要去感悟人生去了。以上仅为个人学习整理,如有错漏,大神勿喷~~

时间: 2024-10-06 15:51:32

LAMP平台基于NFS实现web服务器负载均衡的相关文章

LVS详解及基于LVS实现web服务器负载均衡

前言 LVS(Linux Virtual Server)Linux虚拟服务器,是一个虚拟的服务器集群系统.本项目在1998年5月由章文嵩博士成立,是中国国内最早出现的自由软件项目之一.通过LVS提供的负载均衡技术和Linux操作系统可实现一个高性能.高可用的服务器群集,从而以低成本实现最优的服务性能. 集群基础 集群简介 集群(Cluster)是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用

CentOS 6.5实现LAMP+NFS双web服务负载均衡

CentOS 6.5实现LAMP+NFS双web服务负载均衡 环境说明: CentOS 6.5最小化安装,安装相应的组件: [[email protected] ~]# yum groupinstall -y"Development tools" [[email protected] ~]# yum groupinstall -y"Server Platform Development" 准备三台主机: httpa: 192.168.1.217  搭建web服务器

公司网络web服务器负载均衡解决方案

公司网络web服务器负载均衡解决方案 随着公司产品业务的推广发展壮大,对服务器的硬件性能.相应速度.服务稳定性.数据可靠性的要求越来越高.今后服务器的负载将难以承受所有的访问.从公司的实际情况,运营成本网络安全性考虑,排除使用价格昂贵的大型服务器.以及部署价格高昂的专用负载均衡设备. DNS轮询负载均衡解决方案虽然成本低廉但是安全性能不是很好,加上公司产品的特殊性需要用户验证的体系,在会话保持方面是一大缺陷,会话保持,如果是需要身份验证的网站,在不修改软件构架的情况下,这点是比较致命的,因为DN

HAProxy+Keepalived实现Web服务器负载均衡

2014年03月31日  HAProxy  暂无评论  被围观 12,941次+ 说明: 操作系统:CentOS 5.X 64位 Web服务器:192.168.21.127.192.168.21.128 站点:bbs.osyunwei.com和sns.osyunwei.com部署在两台Web服务器上 实现目的: 增加两台服务器(主主模式),通过HAProxy+Keepalived实现Web服务器负载均衡 架构规划: HAProxy服务器:192.168.21.129.192.168.21.130

web服务器负载均衡与集群基本概念二

前面已经说过负载均衡的作用是在多个节点之间按照一定的策略(算法)分发网络或计算处理负载.负载均衡可以采用软件和硬件来实现.一般的框架结构可以参考下图.    后台的多个Web节点上面有相同的Web应用,用户的访问请求首先进入负载均衡分配节点(可能是软件或者硬件),由它根据负载均衡策略(算法)合理地分配给某个Web应用节点.每个Web节点相同的内容做起来不难,所以选择负载均衡策略(算法)是个关键问题.下面会专门介绍均衡算法. web负载均衡的作用就是把请求均匀的分配给各个节点,它是一种动态均衡,通

分别使用Nginx反向代理和Haproxy调度器实现web服务器负载均衡

1.1 使用nginx实现静态分离得负载均衡集群 1.1.1 Nginx负载均衡基础知识 本实验使用的主机是: 主机 IP地址 角色 centos23.cn 192.168.3.23 Nginx反向代理服务器 centos24.cn 192.168.3.24 web服务器 centos25.cn 192.168.3.25 web服务器 网络拓扑图: Nginx的upstream负载的5种方式,目前最常用得前3种方式 1.轮询(默认) 每个请求按时间顺序逐一分配到不同得后端服务器,如果后端服务器d

Web服务器负载均衡的几种方案 : DNS轮询

本篇主要讲一下最简单的方案——DNS轮询. DNS轮询 大多域名注册商都支持多条A记录 的解析,其实这就是DNS轮询 ,DNS 服务器 将解析请求按照A记录 的顺序,逐一分配到不同的IP上,这样就完成了简单的负载均衡 . 优点 基本上无成本,因为往往域名注册商的这种解析都是免费的: 部署方便,除了网络拓扑的简单扩增,新增的Web服务器只要增加一个公网IP即可. 缺点 健康检查,如果某台服务器宕机,DNS服务器是无法知晓的,仍旧会将访问分配到此服务器.修改DNS记录全部生效起码要3-4小时,甚至更

利用lvs-nat实现两台web服务器负载均衡的简单案例

写在前面:如果此文有幸被某位朋友看见并发现有错的地方,希望批评指正.如有不明白的地方,愿可一起探讨. 案例拓扑图 配置主机1 安装ipvsadm # yum -y install ipvsadm # ipvsadm -A -t 10.170.2.80:80 -s rr # ipvsadm -a -t 10.170.2.80:80 -r 192.168.3.101 -m # ipvsadm -a -t 10.170.2.80:80 -r 192.168.3.102 -m # echo 1 > /p

linux学习笔记——搭建基于nginx的web服务器、多核配置、nginx配置参数

############ 认识nginx #############Nginx:(发音同 engine x)是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.由俄罗斯的程序设计师Igor Sysoev所开发,最初供俄国大型的入口网站及搜寻引擎Rambler(俄文:Рамблер)使用.  其优点是轻量级(占有内存少),高并发(并发能力强),事实上nginx的并发能力确实在同类型的网页伺服器中表现较好.目前中国大陆使用ngi