基于轮询解析+共享存储(NFS)的LAMP

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

之前的博文中我己经介绍过了基于不同的主机来实现LAMP,那时我用开了三台虚拟机,这次将说明用五台虚拟机,模拟一个相对简单的生产环境。直接上图(画的不好,请各位看官多多包涵)

wKioL1MxyXXxprq2AAIYgfjG0Xk421.bmp

一、预备知识:

1、深入了解DNS工作原理

2、编译安装软件包

3、apache服务的工作流程

4、网站的静动区分

5、数据库基础知识

6、网络共享

7、lvm

如果你具备以上知识,那么上图将一目了然(只是我画的太烂了)

二、简单的说明一下上图所能够实现的功能

1、如果有大量的请求是能过DNS智能分配置流量,减小前端APACHE1和APACH2单独压力,当前端一个服务器出现故障时,不会让业务下线。

2、在PHP服务器上挂载一个存储设备,做为PHP与APACHE利用NFS服务共享存储,存放静态或动态资源便于集中式的管理。

3、结合mysql数据库来存储业务数据。

三、本机环境及所用到的软件版本

系统:centos6.5.x86_64

DNS:BIND 9.8.2rc1-RedHat-9.8.2-0.17.rc1.el6_4.6

HTTPD:采用编译安装httpd-2.4.9.tar.bz2

PHP:采用编译安装PHP-5.4.26.tar.bz2

mysql:采用通用二进制安装mysql-5.5.33.tar.bz2

四、配置过程

1、配置DNS服务器(仅正向解析)

前提:

为DNS设置IP地址,主机名,DNS.

在本实验中DNS配置如下

主机名:www.dns.essun.com

IP地址:eth0:192.168.1.50/24,eth0:0 10.01.10.10/8

DNS: 192.168.1.50

功能:为其它域内主机解析

使用yum安装bind,修改配置文件

1
#vim /etc/named.conf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
options {
     directory    "/var/named" ;
         rrset-order { order random; };
};
#rrset-order 支持三个参数:fixed, random, cyclic 。
#fix 会将多个A记录按配置文件的顺序固定给出
#random 会随机给出
#cyclic 会循环给出.
zone  "."  IN {
     type  hint;
     file  "named.ca" ;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              
};
zone  "essun.com"  IN {
     type  master;
     file  "essun.com.zone" ;
};
zone  "localhost."  IN {
     type  master;
     file  "named.localhost" ;
};
#include "/etc/named.rfc1912.zones";
#include "/etc/named.root.key";

②配置数据区域文件(#vim /var/named/essun.com.zone)

wKiom1Mx0-ixXrxLAAHW5FPaCHk544.jpg

③写完之后进行语法检查

1
2
3
4
检查语法
#named-checkconf
检查数据文件
#named-checkzone  "essun.com"  "/var/named/essun.com.zone"

④如果没有错误,就可以启动DNS服务,为其它服务器解析

测试一下:

wKioL1MyPcriUhChAAIzOnPwVg4455.jpg

注:

如果你对以涉及到的知识有疑问请参阅(DNS配置)

⑤将DNS添加到开机启动服务列表,这样就可以开机自动启动服务了

wKiom1MyQcuQxdxBAAC79Hmq5VE736.jpg

======================================到此DNS安装完成=================================

2、编译安装HTTPD

前提:

配置网络属性

第一台HTTPD服务器

主机名:www.apache.essun.com

IP地址:eth0:192.168.1.10/24

DNS:192.168.1.50

第二台HTTPD服务器

主机名:www.apache.essun.com

IP地址:eth0:192.168.1.20/24

DNS:192.168.1.50

先行安装两台APACH服务器。具体配置过程请参考前一篇博文中的编译安装APACHE部分,其过程完全一样。此处略过。

httpd-vhost文件内容如下:(两台配置文件完全相同)

wKioL1MyoibjlhuDAAHsPdVDVak343.jpg

注:

在写虚拟主机通过fcgi来处理php请求时的地址要指向本实验的PHP服务器的IP地址

②在每一台服务器上添加一个普通用户,用于可以访问共享,要与NFS服务器上新建的用户UID相同

1
2
#useradd u 1000 http
# echo "http" | passwd --stdin http

========================================================================================

3、编译安装PHP

前提:

配置网络属性

主机名:www.php.essun.com

IP地址:eth0:192.168.1.30/24

DNS:192.168.1.50

①具体安装安装过程请参阅(安装PHP部分

②要修改监听的IP地址。

③安装nfs.

1
#yum install nfs -y

④挂载一个新硬盘或分区到PHP服务器站点目录

wKiom1MyR83RcxwHAACPE-xcCII952.jpg

⑤共享此目录

wKioL1MySMOR1ZawAACrGSVm-eo701.jpg

⑥添加一个用户

1
2
#useradd u 1000 http
# echo "http" | passwd --stdin http

⑦给共享目录授权

1
2
#chown -R root:http /www/web
#chmod -R 775 /www/web

⑧启动NFS服务

1
#service nfs start

===================================到此PHP与NFS安装完毕=============================

4、安装Mysql

前提

配置网络属性

主机名:www.mysql.essun.com

IP地址:eth0:192.168.1.40/24

DNS:192.168.1.50

①安装过程请参阅(mysql安装

②新建立一个数据库

1
mysql>create database  test ;

wKiom1MyWRHz25QWAAD3U4ffH44296.jpg

③授权用户

1
mysql>GRANT ALL PRIVILEGES ON  test .* TO  'root' @ '192.168.1.30' IDENTIFIED BY  'mysql'  ;

===============================================mysql相关配置完成========================

5、测试

1、安装discuz

下载最新版本的discuz解压到PHP的共享站点目录

wKioL1MyX5CAI1sTAADLkY55JZ4828.jpg

注:

修改配置文件

1
2
3
#cd /www/web/upload/config
#cp config_global_default.php config_global.php
#vim config.global.php

wKioL1Mym1ewwjdVAAG0wrWCcHs050.jpg

要对upload目录给权限(安装需要)

#chmod 777 upload/

2、将PHP上的共享目录挂载到前端

wKiom1MynLGR0TvNAARjLbZaCfw820.jpg

注:APACHE1的挂载方法与此相同。

3、安装discuz

通过浏览器访问www.aache.essun.com/upload就可以在web界面安装discuz论坛了,安装完成后,会让你输入管理员密码,确认后就可以管理论坛了。

4、网络测试

注:

我的测试环境

物理机:

wKiom1MynnyCQeLPAAF_LWCXLbE513.jpg

通过VMnet1与虚拟机中的DNS相连。

wKioL1MynqCz7U2WAAGL4L9XnXc682.jpg

虚拟机中的其它服务器通过VMnet8相连

wKioL1MynuGx6bGiAAGRJ77dvWo415.jpg

(经过多方测试,还是用了VMnet8,这样10段的网络相当于没有生效。。。)

物理机与虚拟机的服务器测试

wKiom1Myn5fTRWuBAAFza-tvz_c197.jpg

5、论坛测试

APACHE1

wKioL1Myn8WgY8gLAAHw55C8E2E023.jpg


APACHE2

wKioL1Myn-ORW0kyAAJf8_enIwQ854.jpg

FQDN

wKioL1MyoAOQr7yQAAJ5eFp6jAM803.jpg

注:

由于两台主机的FQDN相同,所以无法判断访问的是那一台主机,那我用dig测试一下,服务是怎么响应的

dig -t A www.apache.essun.com @192.168.1.50

wKiom1MyoQ6w8qPsAAEZIiMObnA644.jpg

第二次

wKiom1MyoTHS2tu1AAG7cYG0448221.jpg

第三次

wKiom1MyoUqwXCWZAAG4K7qVo9U392.jpg

看到了吧,DNS随机解析,也不能说明就能实现智能解析,我们知道DNS解析过的域名是有缓存的,所以用这种方式还是不妥的,这里仅是实验,将之前的知识结合起来运用,就没有问题了

===================================到此本实验测试结束================================










本文转自 jinlinger 51CTO博客,原文链接:http://blog.51cto.com/essun/1384682,如需转载请自行联系原作者
目录
相关文章
|
26天前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
35 3
|
3月前
|
存储 缓存 前端开发
Django 后端架构开发:存储层调优策略解析
Django 后端架构开发:存储层调优策略解析
53 2
|
2月前
|
存储 关系型数据库 MySQL
深入解析MySQL数据存储机制:从表结构到物理存储
深入解析MySQL数据存储机制:从表结构到物理存储
151 1
|
2月前
|
数据采集 存储 JavaScript
构建您的第一个Python网络爬虫:抓取、解析与存储数据
【9月更文挑战第24天】在数字时代,数据是新的金矿。本文将引导您使用Python编写一个简单的网络爬虫,从互联网上自动抓取信息。我们将介绍如何使用requests库获取网页内容,BeautifulSoup进行HTML解析,以及如何将数据存储到文件或数据库中。无论您是数据分析师、研究人员还是对编程感兴趣的新手,这篇文章都将为您提供一个实用的入门指南。拿起键盘,让我们开始挖掘互联网的宝藏吧!
|
3月前
|
存储 Kubernetes 容器
k8s创建NFS动态存储
k8s创建NFS动态存储
|
3月前
|
存储 缓存 NoSQL
深入解析Memcached:内部机制、存储结构及在大数据中的应用
深入解析Memcached:内部机制、存储结构及在大数据中的应用
|
3月前
|
存储 C# 关系型数据库
“云端融合:WPF应用无缝对接Azure与AWS——从Blob存储到RDS数据库,全面解析跨平台云服务集成的最佳实践”
【8月更文挑战第31天】本文探讨了如何将Windows Presentation Foundation(WPF)应用与Microsoft Azure和Amazon Web Services(AWS)两大主流云平台无缝集成。通过具体示例代码展示了如何利用Azure Blob Storage存储非结构化数据、Azure Cosmos DB进行分布式数据库操作;同时介绍了如何借助Amazon S3实现大规模数据存储及通过Amazon RDS简化数据库管理。这不仅提升了WPF应用的可扩展性和可用性,还降低了基础设施成本。
80 0
|
3月前
|
数据采集 存储 JavaScript
构建你的首个Python网络爬虫:抓取、解析与存储数据
【8月更文挑战第31天】在数字时代的浪潮中,数据成为了新的石油。了解如何从互联网的海洋中提取有价值的信息,是每个技术爱好者的必备技能。本文将引导你通过Python编程语言,利用其强大的库支持,一步步构建出你自己的网络爬虫。我们将探索网页请求、内容解析和数据存储等关键环节,并附上代码示例,让你轻松入门网络数据采集的世界。
|
3月前
|
存储 Kubernetes 数据安全/隐私保护
在K8S中,如果后端nfs存储的ip发生变化如何解决?
在K8S中,如果后端nfs存储的ip发生变化如何解决?
|
4月前
|
Java Scala C++
云计算存储问题之中心NFS服务器如何解决
云计算存储问题之中心NFS服务器如何解决

推荐镜像

更多