以php7.4和php5.6为例:
# 这里在 /usr/local/src/ 目录下进行 cd /usr/local/src/ wget https://mirrors.sohu.com/php/php-5.6.40.tar.gz wget https://mirrors.sohu.com/php/php-7.4.9.tar.gz
2、解压并进入编译
# 步骤一
tar -zxvf php-7.4.9.tar.gz
# 步骤二
cd php-7.4.9
# 步骤三 配置编译参数
./configure --prefix=/usr/local/php74 --with-config-file-path=/usr/local/php74/etc \--with-fpm-user=www --with-fpm-group=www --enable-fpm --enable-opcache --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd
#5.6
./configure --prefix=/usr/local/php56 --with-config-file-path=/usr/local/php56/etc \--with-fpm-user=www --with-fpm-group=www --enable-fpm --enable-opcache --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd
# 如成功无报错则直接进行步骤四
# 如 configure 报 No package "openssl" found、No package "libxml2" found 等错误
# 少哪个装哪个,装完再执行上面的步骤三,解决报错直到配置编译环境通过,这里以 CentOS7 为例
# 搜索报错重的 openssl/libxml2-devel.x86_64 包
yum search openssl
yum search libxml2
# 找到并安装对应的 openssl-devel.x86_64/libxml2-devel.x86_64 包
yum -y install openssl-devel.x86_64 libxml2-devel.x86_64
# 步骤四
make && make install
3、查看 PHP 是否安装成功
# /usr/local/php74 是在步骤三中的 --prefix=/usr/local/php74 指定的
/usr/local/php74/bin/php -v
# /usr/local/php56 是在步骤三中的 --prefix=/usr/local/php56 指定的
/usr/local/php56/bin/php -v
4、设置快捷命令
vi ~/.bash_profile
# PATH之前 加入以下几行后保存退出
alias php74="/usr/local/php74/bin/php"
alias php-fpm74="/usr/local/php74/sbin/php-fpm"
alias php56="/usr/local/php56/bin/php"
alias php-fpm56="/usr/local/php56/sbin/php-fpm"
5、编译安装扩展示例(7.4为例,其他版本同)
# 下载需要安装扩展的 php 相同版本的 php 源码包,解压并进入源码包的 ext/ 目录
# 若是第三方扩展则下载对应的扩展包,解压并进入解压后的文件目录,然后执行 phpize
cd /usr/local/src/php-7.4.9/ext/
# 在 ext/ 目录下可以看到 php 所有的原生扩展,以 bcmath 为例
cd bcmath
# 执行 phpize
/usr/local/php74/bin/phpize
# 配置编译
./configure --with-php-config=/usr/local/php74/bin/php-config
# 编译并且安装
make && make install
# 查看扩展是否安装成功
php74 -m | grep bcmath
# 在 /usr/local/php74/etc/php.ini 中加入 `extension = bcmath.so`
6、修改 php-fpm 监听端口
# 编辑 php-fpm 配置文件,如找不到可使用 `find / -name php-fpm.conf` 命令
vim /usr/local/php74/etc/php-fpm.conf # 去掉 `; pid = run/php-fpm.pid` 前面的分号注释,打开 pid 配置
vim /usr/local/php74/etc/php-fpm.d/www.conf # 输入 /9000 回车,找到 listen = 127.0.0.1:9000 这一行将 9000 修改为 9074
# php56 版本路径和 php74 版本略有不同,默认没有引入外部配置,打开 pid, 将端口修改为 9056
vim /usr/local/php56/etc/php-fpm.conf
# 关闭并重启 php-fpm
killall php-fpm
php-fpm74
php-fpm56
#同/usr/local/php74/sbin/php-fpm和/usr/local/php56/sbin/php-fpm
#如果系统本身有yum安装的php,则需要再执行这个
systemctl start php-fpm
# 打开了 pid 配置后,可使用过以下命令关闭或重启 php-fpm
# INT, TERM 立刻终止
# QUIT 平滑终止
# USR1 重新打开日志文件
# USR2 平滑重载所有worker进程并重新载入配置和二进制模块
# php-fpm 关闭:
kill -INT `cat /usr/local/php74/var/run/php-fpm.pid`
kill -INT `cat /usr/local/php56/var/run/php-fpm.pid`
# php-fpm 重启:
kill -USR2 `cat /usr/local/php74/var/run/php-fpm.pid`
kill -USR2 `cat /usr/local/php56/var/run/php-fpm.pid`
7、Nginx 配置多版本 PHP 解析
话不多说,直接贴配置
server {
listen 80;
# 设置 IP 或者 域名
server_name www.xxx.com;
set $root "/usr/local/share/html";
charset utf-8;
#access_log logs/host.access.log main;
location / {
root $root;
index index.php index.html index.htm;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:90xx
# php74 匹配路由根据自己需要自行配置
location /php74 {
root $root;
fastcgi_pass 127.0.0.1:9074; # 这里端口需和前面 php-fpm 修改的端口保持一致
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# php56
location /php56 {
root $root;
fastcgi_pass 127.0.0.1:9056; # 这里端口需和前面 php-fpm 修改的端口保持一致
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# 没有匹配到以上两种路由,默认走 php74
location ~ \.php$ {
root $root;
fastcgi_pass 127.0.0.1:9074;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
# 重启 Nginxsystemctl restart nginx.service