LAMP环境搭建之编译安装指南(php-5.3.27.tar.gz)

2024-08-30 14:32

本文主要是介绍LAMP环境搭建之编译安装指南(php-5.3.27.tar.gz),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

测试环境:CentOS release 6.5 (Final)

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

1、mysql安装详见:https://www.cnblogs.com/su-root/p/11210794.html

2、apache安装详见:https://www.cnblogs.com/su-root/p/11182549.html

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  -----(https://excellmedia.dl.sourceforge.net/project/korwah/source/libiconv/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:https://www.php.net/distributions/php-5.3.27.tar.gz

[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/bin
ln -s -f /application/php5.3.27/bin/phar.phar /application/php5.3.27/bin/phar
Installing 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/php
lrwxrwxrwx 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.conf
LoadModule 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 bqh
id: bqh:无此用户
[root@bqh-119 conf]# groupadd bqh
[root@bqh-119 conf]# useradd bqh -s /sbin/nologin -M -g bqh 
[root@bqh-119 conf]# id bqh
uid=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 
# <URL:http://httpd.apache.org/docs/2.2/vhosts/>
# 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 <VirtualHost> block.
#
<VirtualHost *:80>ServerAdmin 1147076062@qq.comDocumentRoot "/var/html"ServerName test_phpinfo.phpServerAlias index.phpErrorLog "logs/php-error_log"CustomLog "|/usr/local/sbin/cronolog /application/apache/logs/access_php_%Y%m%d.log" combined
</VirtualHost>

注:

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

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

[root@bqh-119 html]# cat test_phpinfo.php 
<?phpphpinfo();
?>

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

[root@bqh-119 extra]# /application/apache/bin/apachectl -t
Syntax 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 
<?php
$link_id=mysql_connect('localhost','root','bqh123') or mysql_error();
if($link_id) {echo "MySQL connection succeeded!";}
else {echo mysql_error();}
?>

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

ok测试没有问题。

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

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

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

这篇关于LAMP环境搭建之编译安装指南(php-5.3.27.tar.gz)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121082

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.