实验一
实验要求:
(1) nfs server导出/data/application/web,在目录中提供wordpress;
(2) nfs client挂载nfs server导出的文件系统至/var/www/html;
(3) 客户端(lamp)部署wordpress,并让其正常访问;要确保能正常发文章,上传图片;
(4) 客户端2(lamp),挂载nfs server导出的文件系统至/var/www/html;验正其wordpress是否可被访问; 要确保能正常发文章,上传图片;
实验规划:
1、web1: 172.18.252.160 和172.18.251.75 :Apche2.4(编译安装)、php(编译安装)
2、mariadb server:172.18.252.227:mariadb
(通用二进制)
3、NFS服务器;存放网页文件
4、DNS中做轮询,分别指向两台web服务器,起到负载均衡的作用
5、搭建wordpress
网络拓扑图如下:
实验准备:
用lftp命令到主机172.18.0.1下载所需的源码包,如下
实验步骤:
1、Web服务器操作步骤:
1.1 yum安装编译开发环境:
yum groupinstall "Development Tools" "Server Platform Development" -y
1.2 编译安装apr-1.4.6: [注意:因为httpd2.4依赖apr和apr-util是1.4以上版本]
tar -jxvf apr-1.4.6.tar.bz2
cd apr-1.4.6
./configure --prefix=/usr/local/apr
make && make install
1.3编译安装Apr-util
cd apr-util-1.5.2
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
make && make install
1.4 编译安装Apache-2.4
注意这里需要指明apr、apr-util的安装路径,否认系统会自动搜寻,如果系统上有1.4以下的版本的apr就可能会报错!
./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd/ --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=prefork
1.5 检查apache用户是否存在,为httpd2.4进程运行
id apache
注:如果没有则创建之
group add -r -g 48 apache
useradd -r -u 48 apache
1.6 修改apache配置文件,以apache用户身份运行web进程
vim /etc/httpd/httpd.conf
/User
User apache #第164行
Group apache #第165行
1.7 安装编译php所需的环境
yum -y install zlib zlib-devel bzip2 bzip2-devel freetype freetype-devel libmcrypt libmcrypt-devel libxml2 libxml2-devel libxslt libxslt-devel libpng libpng-devel libjpeg-turbo libjpeg-turbo-devel curl libcurl-devel gd-devel openssl
注意:此处devel包需要配置EPEL源哦!
1.8 编译安装libiconv
wget #利用wget命令到服务上下载libiconv
tar xf libiconv-1.15.tar
cd libiconv-1.15
./configure --prefix=/usr/local/libiconv
make && make install
1.9 编译安装php
./configure --prefix=/usr/local/php --with-config-file-path=/etc/php/php.ini --with-config-file-scan-dir=/etc/php.d/ --with-apxs2=/usr/local/apache/bin/apxs --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-bz2 --enable-xml --with-xsl --with-libxml-dir --with-mcrypt --with-openssl --with-curl --with-iconv=/usr/local/libiconv --enable-sockets --enable-short-tags --enable-static --enable-gd-native-ttf --enable-ftp --enable-maintainer-zts --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd
1.10 编辑php配置文件
mkdir /etc/php/
cp /testdir/php-5.4.26/php.ini-production /etc/php/php.ini
vim /etc/php/php.ini
data.timezone = "Asia / Shanghai" #修改时区
1.11 编辑apache主配置文件
vim /etc/httpd/httpd.conf
LoadModule php5_module modules/libphp5.so
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
DirectoryIndex index.php index.html
注:加载libphp5.so需要相对路径,所有/usr/local/apache需要写入环境变量中,如下所示:
export PATH=/usr/local/apache:/usr/local/apache/bin:$PATH
1.12 编写一个php测试页面,测试是否能访问
vim /usr/local/apache/htdocs/index.php
index.php页面代代码如下:
web端访问测试页面
web服务器端就搭建完成了,web1和web2编译安装过程相同。
2、部署MariaDB Server
2.1 通用二进制安装MariaDB
我这里使用的是本地服务器,可以到网上下载二进制包,解压安装包到/usr/lcoal/目录下,并建立mariadb的软连接mysql
ftp://172.18.0.1/pub/Sources/7.x86_64/mariadb/
tar xf mariaadb-5.5.46-linux-x86_64.tar.gz -C /usr/local/
cd /usr/local
ln -sv mariadb-5.5.46-linux-x86_64 mysql
新建mysql用户
id mysql
groupadd -g 27 mysql
useradd -u 27 mysql
设置mysql目录权限
cd /usr/local/mysql/
chown -R root:msyql ./*
mkdir -pv /data/mysql #递归新建mariadb数据存放目录
cp support-files/my-large.cnf /etc/mysql/my.cnf
修改my.cnf 文件,操作如下:
vim /etc/mysql/my.cnf
==============my.cnf===================
datadir = /data/mysql
skip_name_resolve = ON
innodb_file_per_table = ON
=================================
初始化mariadb和启动设置
cp support-files/mysql.server /etc/init.d/mysqld
ll /etc/init.d/mysqld
chkconfig --add mysqld
mv /etc/my.cnf /etc/my.cnf.bak #必须在当前mysql目录下
./scripts/mysql_install_db --user=mysql --datadir=/data/mysql/ #初始化数据
/etc/init.d/mysqld start
#显示信息为: starting MySQL...SUCCESS!
netstat --antlp | grep 3306 #检查进程是否启动
mariadb部署完毕!
2.2 创建数据库
根据规划的架构Mariadb server是独立的数据库服务器,web服务器端要通过php-mysql驱动连接到MariaDB Server是基于TCP/IP协议栈的远程连接,所以需要mariadb数据库服务器授权
CREATE DATABASE mydb;
GRANT PRIVILEGES ON mydb.* TO 'leo' 172.18.252.%' IDENTIFIED BY 'leo' WITH GRANT OPTION;
FLUSH PRIVILEGES;
2.3 查看数据授权信息
数据库服务器搭建完毕!
3、部署NFS Server
在架构中NFS Server用于存放网页数据,提供给前端web1 server和 web2 server正常读写!
3.1 创建目录,解压discuz
mkdir /www && cd www
wget
ftp://172.18.0.1/pub/Sources/sources/php/Discuz_x3.2_SC_UTF8.zip
unzip Discuz_x3.2_SC_UTF8.zip
3.2 创建用户
这里的用户需要跟web server上的apache用户UID,GID一致,这样是为了保证web 服务器挂载NFS后读写权限有效且安装
groupadd -r -g 48 apache
useradd -r -u 48 apache
setfacl -R -m u:apache:rwx /www/
3.3 编辑NFS配置文件
vim /etc/exports
==============exports======================
/www 172.18.252.160(rw,async,all_squash,anonuid=48,anongid=48) 172.18.251.75(rw,async,all_squash,anonuid=48,anongid=48)
================end==========================
service nfs start #启动NFS服务
到此,NFS服务器搭建完毕,网页内容存放下/www/discuz目录下,只允许web1和web2挂载该目录,且对该目录的使用身份映射为NFS Server上的Apache用户,而apache用户对/www/有rwx的权限。
4 . 挂载NFS, 配置web站点
4.1 在web server上挂载nfs server的www目录
mkdir /www/
setfacl -R -m u:apache:rwx /www/
mount -t nfs 172.18.252.199:/www/ /www/
4.2 编辑Apache配置文件
vim /etc/httpd/httpd.conf
---------------------------httpd.conf---------------------------
DocumentRoot "/www/discuz"
.....
----------------------------------------------------
注意,确保web1和web2都挂载和配置完毕,所有服务能正常启动!
5. 测试架构
web端访问discuz论坛能否能正常启动!
具体测试(略)