博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LAMP环境搭建之编译安装指南(php-5.3.27.tar.gz)
阅读量:4696 次
发布时间:2019-06-09

本文共 6938 字,大约阅读时间需要 23 分钟。

测试环境:CentOS release 6.5 (Final)

软件安装:httpd-2.2.27.tar.gz   mysql-5.1.72.tar.gz   php-5.3.27.tar.gz 

1、

2、

3、PHH安装如下:

一、php安装准备

①yum安装php所依赖的包

[root@bqh-119 php]# yum -y install zlib libxml libjpeg freetype libpng gd curl libiconv zlib-devel libxml2-devel libjpeg-devel freetype-devel libpng-devel gd-devel curl-devel

②检测机器是否已经安装好

[root@bqh-119 php]# rpm -qa zlib libxml libjpeg freetype libpng gd curl libiconv zlib-devel libxml2-devel libjpeg-devel freetype-devel libpng-devel gd-devel curl-devel

③安装libiconv-1.14.tar.gz  -----()

 
[root@bqh-119 php]# tar zxf libiconv-1.14.tar.gz cd libiconv-1.14 ./configure --prefix=/usr/local/libiconv make make install

④快速安装libmcrypt扩展库(epel源方法来安装 

[root@bqh-119 yum.repos.d]#wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo[root@bqh-119 yum.repos.d]#yum makecache[root@bqh-119 yum.repos.d]# yum install libmcrypt-devel -y

⑤快速安装mhash加密算法扩展库

  Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下开启,mhash的可以用于场景检验数值,消息摘要,小小认证码,以及无需原文的关键信息保存(如密码)等。

  Mhash为PHP提供了多种哈希算法,如MD5,SHA1,GOST等,你可以通过MHASH_hashname()来查看支持的算法有哪些。

注意问题:该扩展不能提供最新的哈希算法;该扩展结果原则上运算不可逆。

[root@bqh-119 php]# yum install mhash mhash-devel -y

⑥快速安装mcrypt加密扩展库

  php程序员们在编写程序时,除了要保证代码的高性能之外,还有一点是非常重要的,那就是程序的安全性保障。php除了自带的几种加密函数外,还有功能更全面的php加密扩展库mcrypt和mhash。其中,mcrypt扩展可以实现加密解密功能,就是既能将明文密码加

密,也可以密文还原。mcrypt是php里面重要的加密支持扩扎库,该库在默认情况下不开启。编辑本段支持的算法和加密模式:mcrypt库支持20多种加密算法和8中加密模式,具体可以通过函数crypt_list_algorithms()和mcrypt_list_modes()来显示。

[root@bqh-119 php]# yum install mcrypt -y

⑦安装libxslt-devel

[root@bqh-119 php]# yum -y install libxslt-devel

 以上安装php依赖包就ok了。

二、开始安装PHP服务

 ①下载php-5.3.27.tar.gz 并解压。 

下载php:

[root@bqh-119 php]# tar xf php-5.3.27.tar.gz

②编译安装PHP

[root@bqh-119 php-5.3.27]# cd php-5.3.27 [root@bqh-119 php-5.3.27]# ./configure \--prefix=/application/php5.3.27 \            #指定php的安装路径--with-apxs2=/application/apache/bin/apxs \  #指定apache的bin/apxs路径,通过apxs来增加php扩展模块到apache中--with-mysql=/application/mysql \            #指定mysql的安装路径--with-xmlrpc --with-openssl \--with-zlib \--with-freetype-dir \--with-gd \--with-jpeg-dir \--with-png-dir \--with-iconv=/usr/local/libiconv \--enable-short-tags --enable-sockets \--enable-zend-multibyte \--enable-mbstring \--enable-static \--enable-gd-native-ttf \--with-curl \--with-xsl \--enable-ftp \--with-libxml-dir

 执行上边命令后效果如下:

③接着执行:

[root@bqh-119 php-5.3.27]# make && make install  #安装php生成文件至系统..............以上省略/root/tools/php-5.3.27/build/shtool install -c ext/phar/phar.phar /application/php5.3.27/binln -s -f /application/php5.3.27/bin/phar.phar /application/php5.3.27/bin/pharInstalling PDO headers:          /application/php5.3.27/include/php/ext/pdo/[root@bqh-119 php-5.3.27]# echo $?0

④设置软连接安全方便访问:

[root@bqh-119 php-5.3.27]# ln -s /application/php5.3.27/ /application/php[root@bqh-119 php-5.3.27]# ll /application/phplrwxrwxrwx 1 root root 23 7月  19 03:08 /application/php -> /application/php5.3.27/

⑤安装php服务后,我们看一下apache下的模块路径及httpd.conf配置文件中切入了libphp5.so

[root@bqh-119 php-5.3.27]# ll /application/apache/modules/总用量 27824-rw-r--r-- 1 root root     9115 7月  13 23:26 httpd.exp-rwxr-xr-x 1 root root 28479402 7月  19 03:02 libphp5.so #通过apxs来增加php扩展模块到apache中[root@bqh-119 php-5.3.27]# grep libphp5 /application/apache/conf/httpd.confLoadModule php5_module        modules/libphp5.so

注:当用户访问apache时,如何是静态文件,自身解析处理;如果是动态文件,交给php模块解析处理

⑥拷贝php配置文件到php默认目录下并更名为php.ini

[root@bqh-119 php-5.3.27]# ll php.ini-*-rw-r--r-- 1 101 101 69606 7月  11 2013 php.ini-development   #开发-rw-r--r-- 1 101 101 69627 7月  11 2013 php.ini-production    #生产[root@bqh-119 php-5.3.27]# cp php.ini-production /application/php/lib/php.ini

⑦修改apache主配置文件httpd.conf,解决FQDN:

[root@bqh-119 apache]# sed -i 's#\#ServerName www.example.com:80#ServerName 127.0.0.1:80#g' ./conf/httpd.conf[root@bqh-119 apache]# grep ServerName ./conf/httpd.conf# ServerName gives the name and port that the server uses to identify itself.ServerName 127.0.0.1:80

⑧配置apache支持php:在主配置文件httpd.conf第311行后添加下面两行即可:

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

修改damon用户为bqh:

如果不存在bqh用户,配置好文件后,需要创建bqh用户。

注:这个damon用户不是必须修改的,一般情况我们是需要修改用户的,更改默认用户是为了安全考虑。

修改默认的首页文件,例如增加一个index.php:

保存配置后可用diff比对一下:

创建用户:

[root@bqh-119 conf]# id bqhid: bqh:无此用户[root@bqh-119 conf]# groupadd bqh[root@bqh-119 conf]# useradd bqh -s /sbin/nologin -M -g bqh [root@bqh-119 conf]# id bqhuid=503(bqh) gid=503(bqh) 组=503(bqh)

⑨测试php

配置apache主配置文件httpd.conf

[root@bqh-119 extra]# cat httpd-vhosts.conf## Virtual Hosts## If you want to maintain multiple domains/hostnames on your# machine you can setup VirtualHost containers for them. Most configurations# use only name-based virtual hosts so the server doesn't need to worry about# IP addresses. This is indicated by the asterisks in the directives below.## Please see the documentation at # 
# for further details before you try to setup virtual hosts.## You may use the command line option '-S' to verify your virtual host# configuration.## Use name-based virtual hosting.#NameVirtualHost *:80## VirtualHost example:# Almost any Apache directive may go into a VirtualHost container.# The first VirtualHost section is used for all requests that do not# match a ServerName or ServerAlias in any
block.#
ServerAdmin 1147076062@qq.com DocumentRoot "/var/html" ServerName test_phpinfo.php ServerAlias index.php ErrorLog "logs/php-error_log" CustomLog "|/usr/local/sbin/cronolog /application/apache/logs/access_php_%Y%m%d.log" combined

注:

  1. 以上基于前文的基于域名的虚拟主机上基础上配置的,详情至:
  2. 以上日志轮询是采用的cronolog,详情至:
  3. 当然也可以不创建虚拟主机,直接在默认的配置文件、站点目录下配置也行ok。

在新建的/var/html/站点目录下写一个test_phpinfo.php代码测试php

[root@bqh-119 html]# cat test_phpinfo.php 

⑩刷新配置,打开浏览器输入地址结果看是否成功。

[root@bqh-119 extra]# /application/apache/bin/apachectl -tSyntax OK[root@bqh-119 extra]# /application/apache/bin/apachectl graceful

http://192.168.0.118/test_phpinfo.php

我们再看看日志:

[root@bqh-119 extra]# tail -2 /application/apache/logs/access_php_20190720.log 192.168.0.110 - - [20/Jul/2019:12:52:02 +0800] "GET /test_phpinfo.php?=PHPE9568F35-D428-11d2-A769-00AA001ACF42 HTTP/1.1" 200 2146 "http://192.168.0.119/test_phpinfo.php" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 SE 2.X MetaSr 1.0" 192.168.0.110 - - [20/Jul/2019:12:52:02 +0800] "GET /test_phpinfo.php?=PHPE9568F34-D428-11d2-A769-00AA001ACF42 HTTP/1.1" 200 2524 "http://192.168.0.119/test_phpinfo.php" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 SE 2.X MetaSr 1.0"

ok,目前Apache到php已经通了,下面我们需要测试php到mysql是否通。

在站点/var/html/目录下再写一个test_mysql.php代码测试php

[root@bqh-119 html]# vim test_mysql.php[root@bqh-119 html]# cat test_mysql.php 

浏览器输入地址:http://192.168.0.119/test_mysql.php

ok测试没有问题。

假如我们把mysql密码改了,我们再来测试一下效果:

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

到此为止,Apache→php→mysql测试已通; LAMP环境搭建ok。 

转载于:https://www.cnblogs.com/su-root/p/11216210.html

你可能感兴趣的文章
(转载-学习)python wsgi 简介
查看>>
QPushButton 控制两种状态
查看>>
一点小基础
查看>>
PHP 自动加载类 __autoload() 方法
查看>>
JDK中的Timer和TimerTask详解(zhuan)
查看>>
【python练习】ATM&购物商城程序
查看>>
nginx 日志问题(\x22)
查看>>
装饰器、迭代器、生成器
查看>>
类对象作为类成员
查看>>
面向对象和面向过程的区别及优劣对比详解
查看>>
const与指针
查看>>
thsi指针的一些用法及作用
查看>>
c++友元
查看>>
c++运算符重载
查看>>
一元运算符重载
查看>>
Windows 远程栈溢出挖掘
查看>>
(网页)the server responded with a status of 403 (Forbidden)
查看>>
葡萄城报表介绍:Java 报表
查看>>
android 通知消息一
查看>>
UNET学习笔记2 - 高级API(HLAPI)
查看>>