centos安装php环境

安装 PHP 所需扩展

yum install libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel

获取 PHP 源码包

采用源码编译的方式安装 PHP,好处是可以获取最新版本,也能提供一定的配置灵活性,适合有经验的。获取方式可以在 Centos 中运行 Wget ,也可以在其他环境下下载 tar 包然后上传到服务器上。推荐后者,速度更快,此处假设已经获取到了 php-7.4.0.tar.gz,并存放到了 /home/downloads

cd /home/downloads
wget  https://www.php.net/distributions/php-7.4.0.tar.gz

解压

tar -xvf php-7.4.0.tar.gz
cd php-7.4.0

进行配置

对安装进行预配置,设置一些编译参数。最简单的配置是不带任何参数

./configure

但通常因为可能要自定义 PHP 安装目录、配置文件目录等,可以使用个人习惯的基础配置语句:设定PHP安装目录为 /usr/local/php,配置文件目录为 /usr/local/php/etc,并允许使用 php-fpm 管理 PHP 请求

./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm

检查输入无误后即可运行,通常很快完成

make

使用 make 命令进行编译,时间约 5-10min,可能遇到坑。我就在 Centos 7.6 上安装时就遇到了 sqlite3 缺失无法完成的错误提示,然后就执行了yum install sqlite-devel,将 sqlite3 安装上再重新运行 make 命令。(ubuntu的话要执行 sudo apt-get install libsqlite3-dev进行安装)

make

make install

make 无误,make install 很快。

make install

此时 PHP 安装完毕,接下来就要进行相关配置

设置全局变量

刚才设置 PHP 目录在 /usr/local/php,因此该目录下就有了 bin 目录,将 /usr/local/php/bin 添加到全局变量 $PATH

# 编辑文件
vi /etc/profile

# 将下面两句添加到文件尾并保存
PATH=$PATH:/usr/local/php/bin
export PATH

# 刷新生效
source /etc/profile

# 查看是否生效
php -v

参考显示结果
# PHP 7.4.0 (cli) (built: Dec 17 2019 14:44:39) ( NTS )
# Copyright (c) The PHP Group
# Zend Engine v3.4.0, Copyright (c) Zend Technologies

配置 PHP 环境
根据配置时自定义的路径,将有关 PHP 运行的配置文件、启动方式等进行设置,逐一运行下列命令

# 进入PHP源码解压缩目录
cd /home/downloads/php-7.4.0

# 将源码中准备好的配置文件复制到指定目录并改名作为 php 运行时的配置文件,在 ./configure 时指定了配置文件目录是 --with-config-file-path=/usr/local/php/etc
cp php.ini-production /usr/local/php/etc/php.ini

# php-fpm.conf 是 php-fpm 运行时配置文件,里边记录了 include 路径,可以将多个配置文件放到 include 路径下
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

# www.conf 是默认的有关 www 应用的配置
cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf

# 复制 php-fpm 程序到 /etc/init.d,启动、重启或停止 /etc/init.d/php-fpm 即可实现对 PHP 的控制
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

# 赋予 /etc/init.d/php-fpm 执行权限
chmod +x /etc/init.d/php-fpm

上述命令完成后,在不考虑与 Nginx 的配合情况下,PHP 实际已经可以独立工作了,可以启动 php-fpm 并查看相关信息

/etc/init.d/php-fpm start[/restart/stop]

# 输出
Starting php-fpm done

查看 php-fpm 运行情况

ps -ef | grep php

# 输出
root     24080     1  0 09:49 ?        00:00:00 php-fpm: master process (/usr/local/php/etc/php-fpm.conf)
nobody   24081 24080  0 09:49 ?        00:00:00 php-fpm: pool www
nobody   24082 24080  0 09:49 ?        00:00:00 php-fpm: pool www
root     24096 23960  0 09:52 pts/0    00:00:00 grep --color=auto php

# 查看 PHP 配置相关
php -i |grep Config

# 输出
Configure Command =>  './configure'  '--prefix=/usr/local/php' '--with-config-file-path=/usr/local/php/etc' '--enable-fpm'
Configuration File (php.ini) Path => /usr/local/php/etc
Loaded Configuration File => /usr/local/php/etc/php.ini
Configuration

上例中 master process 因为是使用 root 账户启动并运行 php-fpm ,因此显示 root 账户,nobody 是因为默认 www.conf 配置文件中 usergroup 默认值就是 nobody 用户

与 Nginx 的配合

假设现在有站点 a.com,路径是 /home/wwwroot/a.com,为方便区别管理,在 /usr/local/php/etc/php-fpm.d 下新增关于 a.com 的配置文件 a.com.conf 并假设该文件已创建完毕

# 通过复制 www.conf 创建 a.com.conf
cp www.conf a.com.conf

# 编辑目标文件
vi a.com.conf

# 修改 user 和 group 的账号,修改为与 nginx 一致
user = nginx
group = nginx

# 修改监听端口号,即监听 9001 端口,Nginx要将a.com 的请求发到这个端口来(Nginx中设置)
listen = 127.0.0.1:9001

修改 Nginx 配置文件,新增 server 站点,并在 location 中处理 a.comphp 转发

server {
    listen  80;
    server_name  a.com;

    location ~* \.php$ {
        root  /home/wwwroot/a.com/;
        fastcgi_pass    127.0.0.1:9001;
        fastcgi_index   index.php;
        fastcgi_param   SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include         fastcgi_params;
    }
}

注意上面 server 中,有关 .php 的请求被转发去了 127.0.0.1:9001,即 a.com.conf 的设定中,这样两边就配合起来了。以此为例,增加新站点 b.com 时,可以再新建 b.com.conf,并设定 php 监听端口号是 9002Nginx 配置中新增 server 转发到 127.0.0.1:9002,实现同一主机上多个站点的管理。

posted @ 2021-05-18 23:06  牛奔  阅读(488)  评论(0编辑  收藏  举报