LAMP之一:apache、mysql、php的安装及互联互通

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

一、LAMP简介

LAMP(Linux- Apache-MySQL-PHP)网站架构是目前国际流行的Web框架,该框架包括:Linux操作系统,Apache网络服务器,MySQL数据库,Perl、PHP或者Python编程语言,所有组成产品均是开源软件,是国际上成熟的架构框架,很多流行的商业应用都是采取这个架构。LAMP具有通用、跨平台、高性能、低价格的 优势,因此LAMP无论是性能、质量还是价格都是企业搭建网站的首选平台。

二、相关说明

   1、本篇(LAMP系列之一)主要介绍整个平台架构的搭建:Apache2.4.9的编译安装,mysql-5.5.33的安装,php-5.4.26的编译安装,以及整个平台的互联互通;第二篇将介绍《LAMP的性能测试以及安装xcache,为php加速》。

   2、为了模拟环境的真实性,实验中使用3台服务器,Apache服务器,php服务器和Mysql数据库服务器

   3、关于IP:Apache(172.16.251.93),php(172.16.150.150),Mysql(172.16.251.104)

   4、介于在本文中会使用到名称解析,而关于DNS的博文在本博客中已经有两篇,所以这里为了方便,不再搭建DNS服务器,而是使用修改hosts文件来做名称解析

三、Apache2.4.9的编译安装

   1、解决依赖关系

       httpd-2.4.9需要较新版本的apr和apr-util,因此需要事先对其进行升级。事先我们还应该装好开发包组和pcre。

1
2
3
yum -y  install  pcre-devel
yum -y groupinstall  "Development tools"
yum -y groupinstall  "Server Platform Development"

   对于安装过程中使用的apr,apr-util和httpd就使用下图中的这几个

wKiom1MuaxuxkksoAAAMp2MTuT8069.png

    1)编译安装apr

1
2
3
4
# tar xf apr-1.5.0.tar.bz2
# cd apr-1.5.0
# ./configure --prefix=/usr/local/apr
# make && make install

    2)编译安装apr-util

1
2
3
4
# tar xf apr-util-1.5.3.tar.bz2
# cd apr-util-1.5.3
# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
# make && make install

   2、编译安装httpd-2.4.9

1
2
3
4
# tar xf httpd-2.4.9.tar.bz2
# cd httpd-2.4.9
# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd24 --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

   在httpd-2.4.9的安装路径选择上,为了不和系统的httpd冲突,我们指定其安装路径为/usr/local/apache,配置文件装到/etc/httd24中,同时一会儿的服务也要改为httpd24

   选项解释说明:--prefix指定安装路径,--sysconfdir指定配置文件目录,--enalbe-so支持基于DMO的方式动态加载模块,--enable-ssl支持https协议,--enable-cgi支持cgi机制,--enable-rewrite支持URL重写,--with-zlib支持网页数据压缩,--enable-modules=most启用大多数的常用模块,--with-mpm=event默认的mpm模块为event

   3、修改httpd的主配置文件,设置其pid文件的路径 

      因为在httpd2.4中,其pid的位置变的很诡异,不再是在/var/run下,所以我们就给它修改到/var/run下,其实不改也无妨,只要设置对了就好了

1
vim  /etc/httpd/httpd .conf

wKioL1Mud1XjkkckAAA0IirnWQU373.png

  4、提供SysV服务脚本/etc/rc.d/init.d/http24

   这个脚本就不写了,直接稍微改改httpd的服务脚本就好了,先拷贝一份

wKioL1Mud3_BIIJ7AAAsdx0FjJw788.png

 修改httpd的脚本,改为适合httd24的,只需把这几个变量改了就好了,下面的start(),stop()等参数都是调用的这几个变量,所以别的无需修改。保存退出后不需要再给执行权限了,已经有了。

wKiom1Mud7jiWSwvAAA1auzn24g966.png

   5、把httpd24添加到系统服务,并测试

wKioL1MueBjheaJIAACMD5KlBaE337.png

6、导出头文件

wKiom1MueGqiPeYuAAAd53J5uMI513.png

7、导出man帮助手册

wKioL1MueHHy8y8VAAAuiiJjIt4566.png

 8、输出二进制程序

1
2
3
#vim /etc/profile.d/httpd.sh
export  PATH= /usr/local/apache/bin :$PATH
#. /etc/profile.d/httpd.sh

四、安装mysql-5.5.33

1、准备数据存放的文件系统

       因为数据总是在动态增长的,所以我们要创建一个逻辑卷来保存数据。使用/dev/sdb1这个分区来创建逻辑卷。

    1)准备磁盘为LVM格式

wKiom1MugPaiOfC1AABW1sbuHoM802.png

    2)创建lvm并格式化

wKiom1Muf2jy4jp7AABbNZVA1UE129.png

 2、设置开机自动挂载

       这里假设其逻辑卷的挂载目录为/data,而后需要创建/data/mydata目录做为mysql数据的存放目录。

wKioL1Mugx7xYOQrAABMNvQwwZs059.png

   3、查看挂载情况

wKiom1Mug32xG4MBAABPUFnbn0I083.png

   4、为mysql准备系统用户和组

wKiom1Muf6jTngOYAAAil6NRQLY027.png

   5、进入/data挂载目录,创建mydata数据存放的目录,并修改属主和属组

wKioL1MuhHbwOAZdAAAmkD9xzv4425.png

  6、解压mysql并为其创建一个链接,以后升级的时候,直接改链接地址就可以了

wKioL1MugIayDQQ6AAA7f4v-_WM995.png

 7、进入/usr/local/mysql文件夹,修改属主与属组

wKiom1MuhOvhB2o_AABk7flcMSI475.png

8、初始化系统库,进入到/usr/local/mysql

wKiom1MuhWXgtaE4AAAx-MMor2s248.png

9、为mysql提供主配置文件,并修改此文件中thread_concurrency的值为你的CPU个数乘以2,另外还需要添加如下行指定mysql数据文件的存放位置

1
2
# cd /usr/local/mysql
# cp support-files/my-large.cnf  /etc/my.cnf

wKioL1MuhqDzSVs1AABA1SfWHGQ722.png

 10、为mysql提供sysv服务脚本并添加为系统服务

1
2
3
4
5
# cd /usr/local/mysql
# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld
# chmod +x /etc/rc.d/init.d/mysqld
# chkconfig --add mysqld
# chkconfig mysqld on

wKiom1Muh3qDMdW_AABIt8_3PzI200.png

11、启动mysql服务,看能否正常启动

wKioL1Muh4vSm28_AABSM6pGPTY450.png

12、后续操作

为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:

   1)输出mysql的man手册至man命令的查找路径:

       编辑/etc/man.config,添加如下行即可:

       MANPATH  /usr/local/mysql/man

   2)输出mysql的头文件至系统头文件路径/usr/include:

       这可以通过简单的创建链接实现:

       # ln -sv /usr/local/mysql/include  /usr/include/mysql

   3)输出mysql的库文件给系统库查找路径:

       # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

       而后让系统重新载入系统库:

       # ldconfig

   4)修改PATH环境变量,让系统可以直接使用mysql的相关命令。具体实现过程这里不再给出。

       # vim /etc/profile.d/mysql.sh

       #export PATH=/usr/local/mysql/bin:$PATH

       #. /etc/profile.d/mysql.sh

五、编译安装php-5.4.26

 1、编译安装php ,步骤和上面的都一样,就不再给图了,只给步骤

因为我们这里php和mysql服务器是分开部署的,不在本地,所以得考虑到数据库的连接问题。

说明:如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了

1
2
3
4
5
# tar xf php-5.4.26.tar.bz2
# cd php-5.4.26
# ./configure --prefix=/usr/local/php --with-openssl --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --enable-fpm --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd
# make
# make intall

2、为php提供配置文件(我的php解压在了/root/soft下,安装在了/usr/local/php下)

1
cp  /root/soft/php-5 .4.26 /php .ini-production  /etc/php .ini

3、 编辑apache配置文件httpd.conf,以apache支持php

1
2
3
# vim /etc/httpd24/httpd.conf
AddType application /x-httpd-php   .php
AddType application /x-httpd-php-source   .phps

   定位至DirectoryIndex index.html

   修改为:DirectoryIndex  index.php  index.html

六、配置php-fpm

因为Apache服务器连接php服务器是通过fastcgi协议的,因此我们还需通过php-fpm对其进行配置。

   1、为php-fpm提供SysV init脚本,并将其添加至服务列表:

1
2
3
4
# cp /root/soft/php-5.4.26/sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm
# chmod +x /etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on

 2、为php-fpm提供配置文件:

1
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

3、配置php-fpm的相关选项,并启用pid文件

1
2
3
4
5
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8
pid =  /usr/local/php/var/run/php-fpm .pid

pm.max_children:静态方式下开启的php-fpm进程数量。
pm.start_servers:动态方式下的起始php-fpm进程数量。
pm.min_spare_servers:动态方式下的最小php-fpm进程数量。
pm.max_spare_servers:动态方式下的最大php-fpm进程数量。

如果dm设置为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。

如果dm设置为dynamic,那么pm.max_children参数失效,后面3个参数生效。系统会在php-fpm运行开始的时候启动pm.start_servers个php-fpm进程,然后根据系统的需求动态在pm.min_spare_servers和pm.max_spare_servers之间调整php-fpm进程数。

4、修改fpm的默认监听端口

   默认情况下,fpm监听在127.0.0.1的9000端口,也可以使用如下命令验正其是否已经监听在相应的套接字。

   # netstat -tnlp | grep php-fpm

   tcp   0  0  127.0.0.1:9000   0.0.0.0:*   LISTEN   689/php-fpm

所以我们要把监听端口到我们的php服务器上

1
vim  /usr/local/php/etc/php-fpm .conf

wKiom1MumTeRx9pzAAAyjpYKYGE742.png

接下来就可以启动php-fpm并验证其否成功监听了

wKiom1MumjDg_V6ZAABMP1GklfQ641.png

   使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了):

   # ps aux | grep php-fpm

七、配置httpd-2.4.9

1、启用httpd的相关模块

在Apache httpd 2.4以后已经专门有一个模块针对FastCGI的实现,此模块为mod_proxy_fcgi.so,它其实是作为mod_proxy.so模块的 扩充,因此,这两个模块都要加载

       LoadModule proxy_module modules/mod_proxy.so

       LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

wKioL1MunCiB0CRWAAAv1tt3Kr8610.png

   2、配置虚拟主机支持使用fcgi

     1)要使用虚拟主机,首先要关闭中心主机,再开启虚拟主机的模块儿,也是在/etc/httpd24/httpd.conf中

wKiom1Munh-SapEZAAAaMxCsC-I564.png

2)配置虚拟主机

1
vim  /etc/httpd24/extra/httpd-vhosts .conf

wKioL1MuotLDu24MAABk0TIH5e0403.png

ProxyPassMatch:把以.php结尾的文件请求发送到php-fpm进程,php-fpm至少需要知道运行的目录和URI,所以这里直接在fcgi://127.0.0.1:9000后指明了这两个参数,其它的参数的传递已经被mod_proxy_fcgi.so进行了封装,不需要手动指定。所以在Apache服务器和php服务器都应该建立/www/shuishui.com/这个目录,然后把网页文件放到这个目录中来,Apache下要保存静态的index.html和动态的index.php,php服务器上只需保存动态的index.php即可。

   3、继续编辑Apache的主配置文件,让apache能识别php格式的页面,并支持php格式的主页

1
vim  /etc/httpd24/httpd .conf

1)添加如下二行

      AddType application/x-httpd-php  .php

      AddType application/x-httpd-php-source  .phps

   2)定位至 DirectoryIndex index.html

      修改为:DirectoryIndex  index.php  index.html

八、测试Apache服务器与php服务器的互连

在Apache服务器与php服务器下的/www/shuishui.com/目录中分别创建index.php。Apache中的index.php只需要有这个名就可以,因为它会去调用php服务器中的php.index,所以php服务器中的index.php必须要有内容。

给php服务器中的主页文件来个测试页,并重启下服务:

1
service httpd24 restart

wKiom1Mup9nzrHe2AAAetEzx5Pc816.png

到windows上去访问下www.shuishui.com试试,下面就是见证奇迹的时刻

wKioL1MuqbizSTVCAAB9G51_C50764.png

Apache与pah服务器的互联成功

   补充:Apache httpd 2.4以前的版本中,要么把PHP作为Apache的模块运行,要么添加一个第三方模块支持PHP-FPM实现。

九、测试php服务器与mysql服务器的互联

1、在php服务器上的index.php中加入连接mysql服务器的选项

wKiom1Mus53Tq_QbAABCrHrRFt8755.png

  2、测试能否成功连上mysql数据库

wKioL1Mus7ahig9nAABtCNeJ0js160.png

哎,失败了!这是为什么呢?为什么呢?虽然在index.php中要求连接数据库,可是你想使用人家mysql的资源,也不获得mysql的授权,这怎么可以?除非你想黑了它。没那技术就去拿授权吧!

   3、在mysql服务器上授权

wKiom1MutLPgaQouAABnRLaSoNc663.png

4、再来,重新连接

wKioL1MutLShqKEMAAB1JlCXEZ8730.png










本文转自 nmshuishui 51CTO博客,原文链接:http://blog.51cto.com/nmshuishui/1381822,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
16天前
|
网络安全 Apache
Apache服务器安装SSL证书
Apache服务器安装SSL证书
19 0
|
1月前
|
运维 Linux Apache
LAMP架构调优(二)——修改Apache运行用户
LAMP架构调优(二)——修改Apache运行用户
197 1
|
1月前
|
运维 Linux Apache
LAMP架构调优(一)——隐藏Apache版本信息
LAMP架构调优(一)——隐藏Apache版本信息
16 1
|
2月前
|
运维 Unix Linux
Linux系统 PHP安装expect扩展详解
Linux系统 PHP安装expect扩展详解
39 5
|
4月前
|
SQL 分布式计算 数据可视化
Apache Zeppelin系列教程第一篇——安装和使用
Apache Zeppelin系列教程第一篇——安装和使用
74 0
|
3月前
|
关系型数据库 MySQL PHP
|
10天前
|
PHP
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
|
16天前
|
Linux Apache
CentOS 7 源码安装LAMP环境源 和apache监听别的端口
CentOS 7 源码安装LAMP环境源 和apache监听别的端口
12 0
|
27天前
|
应用服务中间件 Linux PHP
Linux下安装php环境并且配置Nginx支持php-fpm模块
Linux下安装php环境并且配置Nginx支持php-fpm模块
29 0
|
1月前
|
运维 Linux Apache
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
199 2

推荐镜像

更多