Windows 本地部署 PHP8.1.32 + Nginx + Redis 后端教程(实测可用)

核心:不用Apache,用Nginx+Redis,适配PHP8.1.32(NTS版),全程实测,新手可直接照做,无多余废话。用了Nginx就用NTS,用Apache就用TS

一、前期准备(必下文件)

  1. PHP:php-8.1.32-nts-Win32-vs16-x64.zip(NTS版,适配Nginx,官网存档下载:https://windows.php.net/downloads/releases/archives/)

  2. Redis扩展:php_redis-5.3.7-8.1-nts-vc16-x64.zip(对应PHP版本,直接下载:https://pecl.php.net/get/redis-5.3.7-8.1-nts-vc16-x64.zip)

  3. Nginx:nginx-1.28.3.zip(稳定版,官网下载:http://nginx.org/en/download.html,选Windows-64)

注意:所有文件解压路径必须纯英文、无空格(示例路径:D:\php81、D:\nginx-1.28.3)。

二、PHP 配置(核心步骤)

  1. 解压PHP到D:\php81,复制php.ini-development,重命名为php.ini。

  2. 打开php.ini,修改3处关键配置(去掉前面分号;):

    1. extension_dir = "ext"

    2. 开启扩展:extension=mysqli、extension=pdo_mysql、extension=redis

    3. 设置时区:date.timezone = Asia/Shanghai

  3. 安装Redis扩展:解压Redis扩展包,将php_redis.dll复制到D:\php81\ext。

  4. 配置环境变量:此电脑→属性→高级系统设置→环境变量→系统变量Path→新增D:\php81,重启CMD。

  5. 验证:CMD输入php -v(显示PHP8.1.32版本)、php -m(显示redis扩展),即为成功。

三、Nginx 配置与启动

  1. 解压Nginx到D:\nginx-1.28.3,打开D:\nginx-1.28.3\conf\nginx.conf,删除原有内容,替换为以下配置(修改root路径为自己的PHP源码路径):

    复制代码
    worker_processes  1;
    events {
        worker_connections  1024;
    }
    http {
        include       mime.types;
        default_type  application/octet-stream;
        sendfile        on;
        keepalive_timeout  65;
        server {
            listen       80;
            server_name  localhost;
            root   D:/php81/www/api; # 替换为你的PHP源码路径
            index  index.php index.html;
            location / {
                try_files $uri $uri/ /index.php?$query_string;
            }
            location ~ \.php$ {
                fastcgi_pass   127.0.0.1:9000;
                fastcgi_index  index.php;
                fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
                include        fastcgi_params;
            }
        }
    }
  2. 启动顺序(必须按此顺序,CMD分开打开):

    1. 启动PHP-CGI:CMD输入 D:\php81\php-cgi.exe -b 127.0.0.1:9000(窗口不要关)

    2. 启动Nginx:新开CMD,依次输入 D: → cd nginx-1.28.3 → start nginx(无提示即为成功)

四、测试与报错解决

  1. 测试:浏览器输入http://localhost,能访问PHP源码内容即为成功。

  2. 常见报错解决:

    1. Nginx报错"找不到nginx.conf":不要双击nginx.exe,必须先cd进入Nginx目录再启动。

    2. 502 Bad Gateway:PHP-CGI未启动,重新执行启动PHP-CGI命令。

    3. 404页面:nginx.conf中root路径写错,核对源码路径并修改。

    4. Redis扩展加载失败:确认扩展版本与PHP版本(NTS、x64、vc16)完全对应。

五、常用命令(备用)

  • 停止Nginx:CMD进入Nginx目录,输入 nginx.exe -s stop

  • 强制杀死Nginx进程:taskkill /f /im nginx.exe

  • 重新加载Nginx配置:nginx.exe -s reload

相关推荐
niucloud-admin1 小时前
PHP V6 单商户常见问题——运行内存太小导致的报错处理
php
nbwenren1 小时前
办公AI实测:Gemini3、GPT-4o、Claude3.5谁更强?
服务器·数据库·php
hopetomorrow2 小时前
学习路之PHP --PHP 常用扩展及作用表
开发语言·学习·php
幽络源小助理3 小时前
影视脚本分镜在线协作系统源码 PHP剧本创作平台
开发语言·php
勤劳的进取家4 小时前
传输层基础
运维·开发语言·学习·php
天疆说4 小时前
Ubuntu 安装微软核心字体
ubuntu·microsoft·php
YaBingSec4 小时前
玄机网络安全靶场:Apache HTTPD 解析漏洞(CVE-2017-15715)WP
java·笔记·安全·web安全·php·apache
chaofan9805 小时前
突破大模型落地瓶颈:Claude 4.7 与 GPT-5.5 长上下文工程实测
数据库·人工智能·python·gpt·自动化·php·api
StockTV5 小时前
韩国股票实时数据 KOSPI(主板)和 KOSDAQ(创业板)的实时行情、K 线及指数数据
java·开发语言·算法·php
合天网安实验室17 小时前
记录一个免杀的php webshell demo
渗透测试·php·webshell·免杀