最佳实践:PHP 安装指南
1. 安装背景与准备
在企业级数据库服务中,用于编写存储过程和函数的丰富环境远超 MySQL 5 所提供的有限环境。它支持标准编程语言,如 Perl 甚至 PHP 本身来编写存储过程,这与 SQL Server 和 Oracle 使用的专有语言不同。而且,大量用于更复杂功能(如地理信息服务)的库使其在企业级数据库服务方面远优于许多其他选择。
在开始安装之前,需要满足以下条件:
- 拥有一台可正常工作的 UNIX 机器,如果没有,GNU/Linux 是基于 PC 硬件的理想类 UNIX 操作系统。安装时要确保安装所有开发工具,因为后续运行 PHP 需要这些工具。
- UNIX 机器已联网,分配了私有 IP 地址,并且可以从工作站对其进行 ping 操作,反之亦然。
- 熟悉基本的 UNIX 命令和实用工具。
准备就绪后,以 root 用户登录到 UNIX 机器(或者使用 su 命令从普通用户账户切换为 root 用户),即可开始安装。
2. 下载并安装 PostgreSQL
由于开发环境仅供个人使用,无需将 PostgreSQL 安装在单独的机器上,可以在同一台机器上运行 Apache、PHP 和数据库,不会对性能产生实际影响。不过,Mac OS X 用户可以从 http://www.postgresql.org/download/macosx 下载向导驱动的安装程序,该程序将几乎无需手动干预即可完成 PostgreSQL 的安装、配置和启动。
对于其他用户,按照以下步骤操作:
1. 从 www.postgresql.org 下载 PostgreSQL 的完整存档,要下载源代码而非二进制文件,以便自行编译以获得最高速度和稳定性。下载的文件名可能类似于 postgresql - 8.3.3.tar.gz 。访问 www.postgresql.org ,点击 “Downloads”,找到源代码链接。可以使用 Lynx 或 FTP 下载文件,但推荐使用 wget :
# wget ftp://ftp.postgresql.org/pub/latest/postgresql-8.3.3.tar.gz
- 下载完成后,以常规方式解压 PostgreSQL:
# tar -xzvf postgresql-8.3.3.tar.gz
这将创建一个名为 postgresql - 8.3.3 的目录,其中包含 PostgreSQL 的源代码。
3. 进入该目录:
# cd postgresql-8.3.3
- 运行配置脚本以生成适合特定 UNIX 环境的
Makefile:
# ./configure
如果一切顺利,不会看到任何错误,并且会看到一系列检查通过,最后一行可能如下所示:
config.status: linking ./src/makefiles/Makefile.linux to src/Makefile.port
- 开始编译过程:
# make
编译 PostgreSQL 可能需要一些时间,可以在此时去喝杯咖啡。编译完成后,安装 PostgreSQL:
# make install
3. 配置 PostgreSQL
虽然 PostgreSQL 已安装,但仍需要进行一些配置:
1. 创建运行守护进程的用户账户:
# adduser postgres
- 创建数据目录并设置权限:
# mkdir /usr/local/pgsql/data
# chown postgres /usr/local/pgsql/data
- 切换到
postgres用户并初始化数据目录:
# su - postgres
# /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
- 指定允许连接的位置。假设服务器的 IP 地址为
192.168.1.1,且只允许从该 IP 地址访问。使用喜欢的编辑器编辑/usr/local/pgsql/data/pg_hba.conf文件,在文件末尾添加以下行:
Host all all 192.168.1.1 255.255.255.255 trust
保存文件并退出编辑器。
5. 启动 PostgreSQL:
# su - postgres
# /usr/local/pgsql/bin/postmaster -i -D /usr/local/pgsql/data &
这里要注意, postmaster 进程必须以新的 postgres 用户身份运行,而不是以 root 或其他登录用户身份运行。 -i 指令也很重要,它告诉 PostgreSQL 允许 TCP/IP 连接,因为默认情况下是禁止的。
4. 创建数据库和用户
可以以 postgres 用户身份创建数据库和用户:
- 创建数据库:
# /usr/local/pgsql/bin/createdb databasename
- 使用 PostgreSQL 控制台操作数据库:
# /usr/local/pgsql/bin/psql databasename
- 创建新用户:
# /usr/local/pgsql/bin/createuser username
5. 安装支持库
在安装 PHP 和 Apache 之前,需要安装一些支持库。PHP 6 大幅减少了实现核心功能所需的外部库数量。主要的 GNU/Linux 发行版在处理这些库的二进制发行版方面也有了很大改进,建议使用喜欢的包管理器(如 yum 、 apt - get 等)安装以下库:
- libicu
- libicu - devel
这两个库包含 Unicode 国际组件的代码,为 PHP 6 中的新 Unicode 支持提供了一些软件基础设施。具体需要哪些额外的库(如果有的话)取决于所需的功能。
6. 安装 PHP 和 Apache
PHP 和 Apache 必须一起安装,以下是具体步骤:
1. Mac OS X 用户可以从 http://www.mamp.info/en/index.php 下载并安装 MAMP,它将使用简单的 “向导” 过程为你创建一个可用的 PHP 6 安装。完成后,你将在 http://localhost:8080 找到 PHP 安装。
2. 对于其他用户,从各自的网站下载 Apache 和 PHP 的最新版本:
- Apache: httpd.apache.org
- PHP: www.php.net
下载的文件可能名为 httpd - 2.2.9.tar.gz 和 php - 6.0.0.tar.gz 。以常规方式解压它们:
# tar -xzvf httpd-2.2.9.tar.gz
# tar -xzvf php-6.0.0.tar.gz
- 对 Apache 进行初始配置:
进入 Apache 目录(可能是httpd - 2.2.9),使用默认参数运行配置脚本,然后编译并安装:
# ./configure
# make && make install
- 配置 PHP:
退出 Apache 目录,进入 PHP 目录:
# cd ..
# cd php-6.0.0
使用以下命令配置 PHP:
./configure -with-aspx2=/usr/local/apache/bin/aspx -with-pgsql --with-pdo-pgsql
如果将 Apache 安装到了不同的前缀,或者使用了 –enable - layout 选项之一,则需要修改 –with - aspx2 指令以指向 aspx 可执行文件的安装位置。
配置可能需要几分钟时间,如果前面的步骤都正确执行,应该不会收到任何错误消息,一切都会配置正常。
5. 构建并安装 PHP:
# make
# make install
make 过程可能需要几分钟,具体取决于服务器的硬件和负载。 make install 通常不会花费太长时间。如果安装失败,可能需要重新检查前面的步骤,特别是要确认上一节中提到的所有支持包都已正确配置。
7. 配置 Apache 使用 PHP 模块
PHP 编译和安装过程会在 Apache 模块目录中创建一个模块,现在需要配置 Apache 以使用该模块。需要告诉 Apache 配置文件如何处理 .php 扩展名。修改 /usr/local/apache/conf/httpd.conf 文件(根据配置参数,此路径可能会有所不同,但这是默认路径),添加以下行:
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
这些行可以添加到文件的几乎任何位置,但为了保持整洁,应将其放在文件中所有其他 AddType 和 AddHandler 指令附近。注意,PHP 应该已经编辑了该文件并添加了以下行:
LoadModule php6_module lib/apache/libphp6.so
确认上述行已经在 httpd.conf 文件中,如果没有,则添加它。
8. 测试安装
最后,测试安装是否成功:
1. 启动 Apache:
# /usr/local/apache/bin/apachectl start
- 在
/usr/local/apache/htdocs目录下创建一个名为test.php的文件,内容如下:
<?php
phpinfo();
?>
保存文件后,在工作站的 Web 浏览器中访问 UNIX 机器的 IP 地址,后面加上 /phpinfo.php 。例如,如果服务器的 IP 地址是 192.168.1.1 ,则访问 http://192.168.1.1/phpinfo.php 。如果看到一个显示 PHP 安装详细信息的页面,那么恭喜你,PHP 安装成功!
9. 在 Windows 上安装 PHP 的注意事项
在某些情况下,可能需要在 Windows 上安装 PHP,例如将封闭系统安装到已经基于 Windows 的大型公司 IT 基础设施中,并且管理层坚决拒绝安装 UNIX 服务器。以下是一些从 UNIX 迁移到 Windows 时的注意事项:
9.1 路径更改
Windows 上的路径与 UNIX 上的路径有很大不同。例如,磁盘上类似 /data/res/1230.jpg 的路径需要更改为 Windows 等效路径,如 C:\data\res\1230.jpg 。不过,PHP 允许使用斜杠 / 。如果使用相对路径避免使用驱动器号,可能会使应用程序更具可移植性。
9.2 外部库
与 UNIX 不同,Windows 没有内置且广泛使用的 C/C++ 编译器,因此 PHP 在 Windows 下运行不需要大量外部库。相反,PHP 的 Windows 安装包提供了大量针对本附录中讨论的各种扩展的预编译 DLL。注意,这些 DLL 仅随 Windows 二进制文件的 ZIP 发行版提供,不建议使用 .msi 安装程序在 Windows 上安装 PHP。
要启用这些扩展,需要确保 PHP 扩展目录在系统 PATH 中(例如 C:\php\ext ),确保 php.ini 中的 extension_dir 指令设置正确(默认情况下,它对于 Windows 安装没有设置为有用的值),然后重启 Web 服务器。这样,相关功能应该会立即对 PHP 可用。
9.3 使用 PEAR
在 Windows 上使用 PEAR 存储库安装库包与在 UNIX 上有所不同。在使用 PEAR 之前,需要使用以下捆绑脚本进行设置:
C:\php\PEAR > ..\php go-pear.php
该脚本会询问有关代理服务器等各种问题,并创建一个 pear 命令作为批处理文件,之后可以像在 UNIX 上一样使用它。
安装流程总结
graph TD;
A[准备 UNIX 环境] --> B[下载并安装 PostgreSQL];
B --> C[配置 PostgreSQL];
C --> D[创建数据库和用户];
D --> E[安装支持库];
E --> F[安装 PHP 和 Apache];
F --> G[配置 Apache 使用 PHP 模块];
G --> H[测试安装];
I[Windows 安装] --> J[路径更改];
I --> K[外部库处理];
I --> L[使用 PEAR];
通过以上步骤,你可以成功安装并配置 PHP 开发环境,无论是在 UNIX 还是 Windows 系统上。在实际开发中,根据具体需求和系统环境进行适当调整,以确保环境的稳定性和性能。
最佳实践:PHP 安装指南(续)
10. 常见问题与解决方案
在安装过程中,可能会遇到一些常见问题,以下是一些解决方案:
- 编译错误 :如果在编译 PostgreSQL 或 PHP 时出现错误,首先检查错误信息,确保所有依赖库都已正确安装。如果缺少某个库,可以使用包管理器进行安装。例如,如果缺少 libicu 库,可以使用 yum install libicu 或 apt-get install libicu 进行安装。
- 配置文件错误 :在修改 Apache 或 PostgreSQL 的配置文件时,可能会出现语法错误。仔细检查配置文件中的每一行,确保没有拼写错误或格式错误。可以使用配置文件检查工具来验证配置文件的正确性。
- 权限问题 :如果在创建目录或文件时遇到权限问题,确保以具有足够权限的用户身份执行操作。例如,在创建 PostgreSQL 数据目录时,需要以 root 用户身份执行 mkdir 和 chown 命令。
11. 性能优化建议
为了提高 PHP 应用程序的性能,可以考虑以下建议:
- 缓存 :使用缓存机制可以减少数据库查询和文件读取的次数,从而提高应用程序的响应速度。可以使用 APC(Alternative PHP Cache)等缓存扩展来实现缓存功能。
- 优化数据库查询 :避免在循环中执行大量的数据库查询,尽量使用批量查询。同时,使用索引来提高数据库查询的效率。
- 压缩代码 :压缩 PHP 代码可以减少文件大小,从而减少网络传输时间。可以使用 Gzip 等压缩工具来压缩代码。
12. 安全注意事项
在安装和使用 PHP 时,需要注意以下安全事项:
- 更新软件 :定期更新 PostgreSQL、PHP 和 Apache 等软件,以修复已知的安全漏洞。
- 设置强密码 :为数据库用户和系统用户设置强密码,避免使用弱密码。
- 限制访问权限 :限制对敏感文件和目录的访问权限,只允许授权用户访问。
13. 总结
通过本文的介绍,你已经了解了如何在 UNIX 和 Windows 系统上安装和配置 PHP 开发环境。以下是安装步骤的总结表格:
| 步骤 | 操作内容 |
| ---- | ---- |
| 1 | 准备 UNIX 环境,确保满足安装条件 |
| 2 | 下载并安装 PostgreSQL |
| 3 | 配置 PostgreSQL |
| 4 | 创建数据库和用户 |
| 5 | 安装支持库 |
| 6 | 安装 PHP 和 Apache |
| 7 | 配置 Apache 使用 PHP 模块 |
| 8 | 测试安装 |
| 9(Windows) | 处理路径更改、外部库和使用 PEAR |
同时,还介绍了常见问题的解决方案、性能优化建议和安全注意事项。在实际应用中,根据具体需求和系统环境进行适当调整,以确保 PHP 开发环境的稳定性、性能和安全性。
14. 安装流程回顾
graph TD;
A[准备 UNIX 环境] --> B[下载并安装 PostgreSQL];
B --> C[配置 PostgreSQL];
C --> D[创建数据库和用户];
D --> E[安装支持库];
E --> F[安装 PHP 和 Apache];
F --> G[配置 Apache 使用 PHP 模块];
G --> H[测试安装];
I[Windows 安装] --> J[路径更改];
I --> K[外部库处理];
I --> L[使用 PEAR];
M[常见问题解决] --> N[编译错误处理];
M --> O[配置文件错误处理];
M --> P[权限问题处理];
Q[性能优化] --> R[使用缓存];
Q --> S[优化数据库查询];
Q --> T[压缩代码];
U[安全注意事项] --> V[更新软件];
U --> W[设置强密码];
U --> X[限制访问权限];
通过遵循上述步骤和建议,你可以顺利搭建一个高效、稳定且安全的 PHP 开发环境,为后续的开发工作打下坚实的基础。在开发过程中,不断积累经验,根据实际情况进行调整和优化,以满足项目的需求。
超级会员免费看

被折叠的 条评论
为什么被折叠?



