LAMP架构实验
— 基础架构搭建
-
实验实验拓扑图与目的
-
实验过程
-
总结与问题
实验实验拓扑图与目的
1. 实验主框架LAMP采用编译安装。
2. 分离HTTPD,PHP,MARIADB。
3. 两台服务器能够各自被访问且内容相同。
实验过程
程序包准备:
apr-1.5.2.tar.gz apr是apache的运行库,提供了软件允许所需要的库文件。
apr-util-1.5.4.tar.gz 可以理解为apr的扩展,支持更加多的数据接口与封装接口。
httpd-2.4.20.tar.bz2 http程序,2.4支持了众多新特性,最为主要的是event模型。
mariadb-5.6.20.tar.gz 完全开源的关系型数据库,是mysql的一个分支。
php-5.6.20.tar.gz php程序,负责解析动态请求。
xcache-3.2.0.tar.gz PHP的加速器程序,能够通过缓存来加速PHP。
phpMyAdmin-4.6.0-all-languages.zip 图形化数据库管理工具,基于PHP开发,可选。
wordpress-4.5.zip 基于PHP开发的开源的blog平台,可选。
Discuz_X3.1_SC_GBK.zip 基于PHP开发的论坛,可选。
软件:
[开发包组]
Development Tools 开发工具包
[apache]
pcre-devel pcre正则表达式支持库
openssl-devel openssl开发包
[PHP]
libxml2-devel xml的开发包
bzip2-devel bzip2的开发包
libmcrypt-devel 加密扩展开发包
mhash-devel mhash加密开发包
配置文件表:
Web Server 1 (192.168.1.1)
编译安装:
[root@host1 ~]# yum groupinstall "Development Tools" -y 安装依赖的包组“Development Tools”
[root@host1 ~]# yum install pcre-devel openssl-devel -y 安装正则表达式的开发包pcre-devel 与 openssl的开发包openssl-devel
[root@host1 ~]# rpm -q apr-util && yum remove apr-util -y 查询apr-util是否安装,安装了就卸载,是为了防止默认安装了低版本的apr而使得非常混乱。
[root@host1 ~]# rpm -q apr && yum remove apr -y 查询apr是否安装,安装了就卸载,是为了防止默认安装了低版本的apr而使得非常混乱。
[root@host1 ~]# rpm -q httpd && yum remove httpd -y 查看httpd是否安装,安装了就卸载,是为了防止默认安装了低版本的httpd。
[root@host1 ~]# useradd -s /sbin/nologin -r apache 创建系统用户并不能登陆,创建用户时会自动创建相同名称的组。
[root@host1 source]# cd source/ cd到存放源码的目录。
[root@host1 source]# tar xf source/apr-1.5.2.tar.gz 解压apr
[root@host1 source]# tar xf source/apr-util-1.5.4.tar.gz 解压apr-util
[root@host1 source]# tar xf source/httpd-2.4.20.tar.bz2 解压httpd
[root@host1 source]# cd apr-1.5.2 cd到apr-1.5.2的目录。
[root@host1 apr-1.5.2]# ./configure --prefix=/usr/local/apr 编译安装的环境检查,生成编译安装配置清单文件,并制定程序存放位置。
[root@host1 apr-1.5.2]# make && make install 编译以及复制文件。
[root@host1 apr-1.5.2]# cd ../apr-util-1.5.4 cd到apr-util目录
[root@host1 apr-util-1.5.4]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr 检查环境,生成编译安装配置清单文件,指定程序存放位置以及apr的安装位置。
[root@host1 apr-util-1.5.4]# make && make install 编译以及复制文件。
[root@host1 apr-util-1.5.4]# cd ../httpd-2.4.20 cd到httpd-2.4.20的目录。
[root@host1 httpd-2.4.20]# ./configure \ 检查环境,生成编译安装配置清单文件。
> --prefix=/web/apache \ 指定程序存放位置。
> --sysconfdir=/etc/httpd \ 指定配置文件存放位置。
> --enable-so \ 启用共享对象
> --enable-ssl \ 启用ssl
> --enable-cgi \ 启用cgi
> --enable-rewrite \ 启用rewrite重写
> --with-zlib \ 启用zlib库
> --with-pcre \ 启用pcre正则
> --with-apr=/usr/local/apr \ 指定apr位置
> --with-apr-util=/usr/local/apr-util \ 指定apr-util位置
> --enable-modules=most \ 启用大部分模块
> --enable-mpms-shared=all \ 启用所有的MPM模型,prefork worker event
> --with-mpm=event 默认启用event模型
[root@host1 source]# make && make install 编译以及复制文件。
[root@host1 source]# cd ~
[root@host1 ~]# echo "export PATH=/web/apache/bin:$PATH" > /etc/profile.d/httpd.sh 写入二进制可执行文件路径至$PATH变量。
[root@host1 ~]# ln -s /web/apache/include /usr/include/httpd 在/usr/include中创建链接指向httpd的头文件
[root@host1 ~]# echo "PidFile \"/var/run/httpd.pid\"" >> /etc/httpd/httpd.conf\ 将PID的路径写入httpd的配置文件
[root@host1 ~]# echo "MANPATH /web/apache/man" >> /etc/man.config 将httpd的man文件路径写入man的配置文件。
[root@host1 ~]# vim /etc/rc.d/init.d/httpd 创建启动脚本,并修改一下主要变量的参数的值,脚本在本文最后提供。
....
apachectl=/web/apache/bin/apachectl
httpd=${HTTPD-/web/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
....
[root@host1 ~]# chmod +x /etc/rc.d/init.d/httpd 给予启动脚本执行权限。
[root@host1 ~]# chkconfig --add httpd 将httpd添加进开机启动。
[root@host1 ~]# chkconfig --level 3 httpd on 将httpd设置为在level 3都启动。
[root@host1 ~]# service httpd start 脚本启动httpd。
文件配置:
[root@host1 ~]# vim /etc/httpd/httpd.conf 配置httpd.conf
LoadModule proxy_module modules/mod_proxy.so 启用代理模块。
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so 启用基于fcgi的传输模块。
User apache 指定子进程的属主。
Group apache 指定子进程的属组。
Include /etc/httpd/extra/httpd-vhosts.conf 开启此项会自动去读hyyp-vhosts.conf这个配置文件。
AddType application/x-httpd-php .php 增加类型识别PHP。
AddType application/x-httpd-php-source .phps 增加类型识别PHPS。
[root@host1 ~]# vim /etc/httpd/extra/httpd-vhosts.conf 编辑httpd-vhost.conf
<Virtualhost *:80> 增加一个虚拟主机。
documentroot "/web/data" 此主机的根目录。
servername www.xiao.com 此主机的服务器名称即域名。
errorlog "/web/log/error.log" 错误日志存放位置。
customlog "/web/log/access.log" common 访问日志存放位置已经格式指定为common这个内置配置。
proxyrequests off 关闭正想代理。
ProxyPassMatch ^/(.*\.php)$ fcgi://192.168.1.3:9000/web/data/$1 将.PHP结尾的文件的请求都通过fcgi转向192.168.1.3:9000/web/data去。
<directory "/web/data"> 此虚拟主机目录/web/data的属性。
options none 目录选项为none。
DirectoryIndex index.php index.html 默认的主页文件为index.php 次之为index.html
allowoverride none 目录配置检查为none。
require all granted 允许多有主机访问,没有做访问控制。
</directory>
</Virtualhost>
[root@host1 ~]# mkdir -pv /web/{data,log} 创建日志文件存放目录。
[root@host1 ~]# service httpd reload 重载配置文件。
网页部署:
[root@host1 ~]# cd source/
[root@host1 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data
[root@host1 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host1 data]# chown -R apache:apache .
注:需要在fastcgi指定的PHP服务器中的路径下拥有相同的文件才可通过http访问192.168.1.1来调用PHP服务器,也就是说此处服务器只是存放一个对应的文件用来映射访问,真正的操作在PHP服务器上执行。
Web Server 2 (192.168.1.2)
编译安装:
编译安装过程与web sever1相同
文件配置:
[root@host2 ~]# vim /etc/httpd/httpd.conf 与web1基本一致,就不做解释了。
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
User apache
Group apache
Include /etc/httpd/extra/httpd-vhosts.conf
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
[root@host2 ~]# vim /etc/httpd/extra/httpd-vhosts.conf
<Virtualhost *:80>
documentroot "/web/data"
servername www.xiao.com
errorlog "/web/log/error.log"
customlog "/web/log/access.log" common
proxyrequests off
ProxyPassMatch ^/(.*\.php)$ fcgi://192.168.1.3:9000/web/data/$1
<directory "/web/data">
options none
DirectoryIndex index.php index.html
allowoverride none
require all granted
</directory>
</Virtualhost>
[root@host2 ~]# mkdir -pv /web/{data,log}
[root@host2 ~]# service httpd restart
网页部署:
[root@host2 ~]# cd source/
[root@host2 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data
[root@host2 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host2 data]# chown -R apache:apache .
注:需要在fastcgi指定的PHP服务器中的路径下拥有相同的文件才可通过http访问192.168.1.2来调用PHP服务器,也就是说此处服务器只是存放一个对应的文件用来映射访问,真正的操作在PHP服务器上执行。
php server (192.168.1.3)
编译安装:
[root@host3 ~]# yum groupinstall "Development Tools" -y 安装依赖包组。
[root@host3 ~]# yum install "libxml2-devel" "bzip2-devel" "libmcrypt-devel" "mhash-devel" -y 安装依赖的包。
[root@host3 ~]# useradd -s /sbin/nologin -r php 创建php程序的属主。
[root@host3 ~]# cd source/
[root@host3 source]# tar xf php-5.6.20.tar.gz 解压php源码包
[root@host3 source]# cd php-5.6.20 CD进php-5.6.20目录
[root@host3 php-5.6.20]# ./configure \ 检查环境,生成编译安装配置清单文件。
--prefix=/usr/local/php \ 指定php程序安装位置。
--with-mysql=mysqlnd \ 指定mysql为mysqlnd驱动,mysqlnd是新版的mysql的驱动。
--with-openssl \ 启用openssl
--with-mysqli=mysqlnd \ 指定mysqli为mysqlnd驱动,mysqli为php-mysql的进阶扩展。
--enable-mbstring \ 支持Multi-Byte String ,编码库。
--with-freetype-dir \ 启用freetype字体引擎。
--with-jpeg-dir \ 启用支持jpeg格式的图片。
--with-png-dir \ 启用支持png格式的图片。
--with-zlib \ 启用支持zlib数据压缩。
--with-libxml-dir=/usr \ 启用xml的支持库,支持xml格式的文件
--enable-xml \ 启用xml功能。
--enable-sockets \ 启用套接字。
--enable-fpm \ 启用fpm,fastcgi管理器。
--with-mcrypt \ 启用加密扩展库mcrypt。
--with-config-file-path=/etc \ 指定配置文件php.ini路径。
--with-config-file-scan-dir=/etc/php.d \ 指定配置文件目录,php.d
--with-bz2
[root@host3 php-5.6.20]# make && make install 编译安装,复制文件
[root@host3 php-5.6.20]# cp php.ini-production /etc/php.ini 复制的配置文件php.ini。
[root@host3 php-5.6.20]# cp lamp/php-5.6.20/sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm 复制php-fpm的启动脚本。
[root@host3 php-5.6.20]# chmod +x /etc/rc.d/init.d/php-fpm 给予启动脚本执行权限。
[root@host3 php-5.6.20]# echo "export PATH=/usr/local/php/bin:/usr/local/php/sbin:$PATH" > /etc/profile.d/php.sh 指定二进制可执行文件。
[root@host3 php-5.6.20]# echo "/usr/local/php/lib" > /etc/ld.so.conf.d/php.conf 写入库文件。
[root@host3 php-5.6.20]# ln -sv /usr/local/php/include /usr/include/php 写入头文件。
[root@host3 php-5.6.20]# echo "MANPATH /usr/local/php/man" >> /etc/man.config 写入man文件。
[root@host3 php-5.6.20]# cp etc/php-fpm.conf.default etc/php-fpm.conf 复制php-fpm的配置文件。
[root@host3 php-5.6.20]# vim etc/php-fpm.conf 编辑php-fpm.conf
pid = /usr/local/php/var/run/php-fpm.pid PID路径
user = php 进程属主
group = php 进程属组
listen = 192.168.1.3:9000 监听的IP,端口。
pm = dynamic 指定进程管理方式为dynamic,动态调整。也可设置为静态static。
pm.max_children = 50 允许的最大的php-fpm子进程数。
pm.start_servers = 5 动态模式下,PHP启动时的php-fpm进程数。
pm.min_spare_servers = 2 动态模式下服务器空闲时最小的php-fpm进程数。
pm.max_spare_servers = 8 动态模式下服务器空闲时最大的php-fpm进程数。
[root@host3 php-5.6.20]# chkconfig --add php-fpm 加入开机自启。
[root@host3 php-5.6.20]# chkconfig --level 3 php-fpm on 在level 3下开机自启动。
[root@host3 php-5.6.20]# service php-fpm start 脚本启动。
xcache加速PHP:
[root@host3 source]# tar xf xcache-3.2.0.tar.gz
[root@host3 source]# cd xcache-3.2.0
[root@host3 xcache-3.2.0]# /usr/local/php/bin/phpize 启用php的环境检查,通过后生成xcache的configure文件
[root@host3 xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config 检查环境,生成编译安装配置清单文件,开启xcache,指定php-config的位置,php-config存放了php的配置信息。
[root@host3 xcache-3.2.0]# make && make install
[root@host3 xcache-3.2.0]# mkdir /etc/php.d
[root@host3 xcache-3.2.0]# cp xcache.ini /etc/php.d 复制xcache.ini到php.d目录下。
[root@host3 xcache-3.2.0]# vim /etc/php.d/xcache.ini 配置xcache.ini
extension = /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/xcache.so 指定共享对象位置。
网页部署:
[root@host3 ~]# mkdir -pv /web/data
[root@host3 ~]# cd source/
[root@host3 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data
[root@host3 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host3 data]# chown -R php:php .
注:此处的网页文件才是用户通过httpd访问到的网页文件,也就是说用户在访问192.168.1.1时访问的网页是位于192.168.1.3上的。
DBserver (192.168.1.4)
二进制文件安装:
[root@host4 ~]# useradd -s /sbin/nologin -r mysql 创建系统用户musql,不允许登陆。
[root@host4 ~]# cd source/
[root@host4 source]# tar xf mariadb-5.5.48-linux-x86_64.tar.gz -C /usr/local/ 解压源码文件并且解压至指定目录。
[root@host4 source]# cd /usr/local
[root@host4 local]# ln -sv mariadb-5.5.48-linux-x86_64 mysql 连接目录为mysql目录
[root@host4 local]# cd mysql
[root@host4 mysql]# chown -R mysql:mysql . 将mysql目录下的文件递归的属主属组都改为mysql
[root@host4 mysql]# bash scripts/mysql_install_db --user=mysql --datadir=/mysql/data 执行安装脚本并且指定进程用户与数据存放路径。
[root@host4 mysql]# chown -R root . 更改属主为root
[root@host4 mysql]# cp support-files/my-large.cnf /etc/my.cnf 复制mysql的配置文件
[root@host4 mysql]# vim /etc/my.cnf 配置my.cnf
thread_concurrency = 4 内核数量*2,指定内部并发数量,决定性能。
datadir= /mysql/data 指定数据存放位置。
[root@host4 mysql]# echo "export PATH=/usr/local/mysql/bin:$PATH" > /etc/profile.d/mysql.sh 写入二进制文件路径。
[root@host4 mysql]# echo "/usr/local/mysql/lib" > /etc/ld.so.conf.d/mysql.conf 写入库文件。
[root@host4 mysql]# ln -sv /usr/local/mysql/include /usr/include/mysql 写入头文件。
[root@host4 mysql]# echo "MANPATH /usr/local/mysql/man" >> /etc/man.config 写入man文件。
[root@host4 mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld 复制脚本启动文件至指定目录。
[root@host4 mysql]# chmod +x /etc/rc.d/init.d/mysqld 执行权限给脚本启动文件。
[root@host4 mysql]# chkconfig --add mysqld 添加进开机自启。
[root@host4 mysql]# chkconfig --level mysqld on 启用开机自启。
[root@host4 mysql]# service mysqld start 启动mysql
网页部署:
[root@host4 ~]# mysql
MariaDB [(none)]> create database dz ;
MariaDB [(none)]> use dz ;
MariaDB [dz]> create table ;
MariaDB [dz]> grant all on dz.* to dzadmin@'192.168.1.3' identified by 'redhat' ;
MariaDB [dz]> flush privileges ;
MariaDB [dz]> exit
总结与问题
总结
-
LAMP架构的实验拖了好多天才动手,结果现在进度到nginx了才开始动手实验,实验过程中,编译安装就是不断出错与解决的问题,遇到出错一般都是软件没有安装。
-
在编译安装前,一定要检查是不是已经默认安装过了程序,不然会非常乱,比如在这次试验中,因为本机已经默认安装了httpd-2.2与apr-1.3.9,apr-util-1.3.X ,所以导致在start httpd的时候启动了2.2的版本,通过rpm -qi才知道。
-
在编译安装完成后,要完成收尾工作,比如配置文件,链接库,链接二进制文件,链接include文件,加启动脚本等。
-
最后的网页部署没有仔细列出步骤,但大致以写出,可以通过google等方式自行查询,这里选择使用的php网页为discuz! 根据喜好也可选择其他如word press等。
-
此次架构实验为第一步的初步搭建LAMP的基本架构,后续会在学习的基础上进一步迭代添加如日志服务器,DNS服务器,负载均衡服务器,代理服务器等。
-
由于本次实验PHP是基于FASTCGI来将PHP服务器独立出来的,所以所有网页文件都需要在每一个服务器上存放一份,会非常麻烦,解决方案就是NFS,留在下一次实验来补充完善。
问题
-
HTTPD搭建完成后无法启动,检查配置文件,发现PID没有指定路径,加上即解决。
-
数据库无法在其他服务器上远程访问,因为用户权限没有赋予指定主机 如 admin@’IPADDR’ 。
-
DISCUZ!在安装完成后,访问主页时CSS错误的问题,是因为采用了FASTCUGI分离了PHP,所以导致生成的缓存的CSS数据只存在在PHP服务器上,而静态数据是要存放在前段的web服务器上的,所以就使得用户访问时,web服务器是找不到缓存中的CSS文件的,解决方法,将远程主机上的CSS缓存文件复制并存放到web服务器的对应目录下。
-
发现远程无法访问的情况,请检查你的selinux与iptables,iptables的具体配置问题会在后续的文章中再来完善。
httpd自动部署脚本(不够完善,漏洞超级多,而且适用环境非常小,只是为了偷懒顺手写的,仅供参考!)
需要将所有的包都存放在/root/source目录下,且请自行修改对应的包名,或者也可以和我使用相同版本的所有包!!!
程序包列表:
apr-1.5.2.tar.gz
apr-util-1.5.4.tar.gz
httpd-2.4.20.tar.bz2
-------------------------------------------------------------------------
脚本代码:
dir=/root/source/
function env() {
yum groupinstall "Development Tools" -y
yum install pcre-devel openssl-devel -y
rpm -q apr-util && yum remove apr-util -y
rpm -q apr && yum remove apr -y
rpm -q httpd && yum remove httpd -y
}
function apr() {
cd ${dir}
tar xf ${dir}apr-1.5.2.tar.gz
tar xf ${dir}apr-util-1.5.4.tar.gz
cd ${dir}apr-1.5.2
./configure --prefix=/usr/local/apr
make && make install
cd ${dir}apr-util-1.5.4
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
make && make install
}
function http() {
[ -e "/web" ] || mkdir -pv /web
cd ${dir}
tar xf ${dir}httpd-2.4.20.tar.bz2
cd ${dir}httpd-2.4.20
./configure --prefix=/web/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=event
make && make install
touch /etc/profile.d/httpd.sh
echo "PATH=/web/apache/bin:$PATH" > /etc/profile.d/httpd.sh
ln -s /web/apache/include /usr/include/httpd
echo "PidFile \"/var/run/httpd.pid\"" >> /etc/httpd/httpd.conf
cd /etc/rc.d/init.d
wget ftp://139.129.54.50/httpd
chmod +x /etc/rc.d/init.d/httpd
chkconfig --add httpd
chkconfig httpd on
}
env
apr
http
service httpd start
ss -tnl | grep "80" && echo "httpd started"
httpd启动脚本(centos6)
#!/bin/bash
#
# httpd Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server. It is used to serve \
# HTML files and CGI.
# processname: httpd
# config: /etc/httpd/conf/httpd.conf
# config: /etc/sysconfig/httpd
# pidfile: /var/run/httpd.pid
# Source function library.
. /etc/rc.d/init.d/functions
if [ -f /etc/sysconfig/httpd ]; then
. /etc/sysconfig/httpd
fi
# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}
# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS=""
# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.
# Path to the apachectl script, server binary, and short-form for messages.
apachectl=/web/apache/bin/apachectl
httpd=${HTTPD-/web/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
RETVAL=0
start() {
echo -n $"Starting $prog: "
LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch ${lockfile}
return $RETVAL
}
stop() {
echo -n $"Stopping $prog: "
killproc -p ${pidfile} -d 10 $httpd
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile}
}
reload() {
echo -n $"Reloading $prog: "
if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then
RETVAL=$?
echo $"not reloading due to configuration syntax error"
failure $"not reloading $httpd due to configuration syntax error"
else
killproc -p ${pidfile} $httpd -HUP
RETVAL=$?
fi
echo
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status -p ${pidfile} $httpd
RETVAL=$?
;;
restart)
stop
start
;;
condrestart)
if [ -f ${pidfile} ] ; then
stop
start
fi
;;
reload)
reload
;;
graceful|help|configtest|fullstatus)
$apachectl $@
RETVAL=$?
;;
*)
echo $"Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
exit 1
esac
exit $RETVAL
原创文章,作者:Net18_肖肖,如若转载,请注明出处:http://www.178linux.com/16118