0

0

php本地部署支持nodejs吗_php与nodejs混合开发环境搭建教程【教程】

看不見的法師

看不見的法師

发布时间:2026-01-01 19:33:08

|

584人浏览过

|

来源于php中文网

原创

php与node.js可在本地并行运行,通过http调用、nginx反向代理、子进程执行、docker编排或websocket通信实现协同。

php本地部署支持nodejs吗_php与nodejs混合开发环境搭建教程【教程】

如果您希望在本地同时运行 PHP 和 Node.js 应用,并实现两者协同工作,例如通过 PHP 调用 Node.js 服务或共享开发端口,需明确二者属于独立运行时环境,不能直接“内置支持”,但可通过进程通信、HTTP 调用或反向代理等方式共存。以下是搭建 PHP 与 Node.js 混合本地开发环境的具体步骤:

一、并行启动独立服务

PHP 和 Node.js 各自启动监听不同端口的 Web 服务,前端通过跨域或代理统一入口访问,避免端口冲突且保持职责分离。

1、使用 PHP 内置服务器启动 PHP 项目:php -S localhost:8000 -t ./public

2、在另一终端中启动 Node.js 服务:node server.js(确保 server.js 中调用 app.listen(3000)

立即学习PHP免费学习笔记(深入)”;

3、配置前端请求:PHP 页面中通过 fetch('http://localhost:3000/api/data') 调用 Node.js 接口

二、Nginx 反向代理统一路由

Nginx 作为前置网关,将不同路径请求分发至对应后端服务,实现单一域名下的混合路由,规避浏览器跨域限制。

1、安装 Nginx 并编辑 nginx.conf 文件,在 http 块内添加 upstream 定义:

2、为 PHP 添加 location 块:location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; ... }

3、为 Node.js 添加 location 块:location /api/ { proxy_pass http://localhost:3000/; }

4、重启 Nginx:nginx -s reload

三、PHP 执行 Node.js 子进程

利用 PHP 的 execproc_open 函数在服务端同步或异步调用 Node.js 脚本,适用于数据处理、图像生成等计算型任务。

Favird No-Code Tools
Favird No-Code Tools

无代码工具的聚合器

下载

1、编写 Node.js 工具脚本 process-data.js,接收命令行参数并输出 JSON 结果

2、在 PHP 中执行:$output = shell_exec('node process-data.js ' . escapeshellarg($input));

3、解析返回值:$result = json_decode($output, true);

四、使用 Docker 统一容器编排

通过 docker-compose.yml 定义 PHP-FPM、Node.js 和 Nginx 三个服务,复用同一网络并挂载共享卷,保障环境一致性。

1、创建 docker-compose.yml,定义 phpnodenginx 三个 service

2、在 nginx 配置中设置 proxy_pass http://node:3000fastcgi_pass php:9000

3、执行:docker-compose up -d

五、WebSocket 实时双向通信集成

PHP 后端通过 HTTP 触发事件,Node.js 启动独立 WebSocket 服务,前端连接该服务接收实时推送,实现 PHP 主控、Node.js 承载长连接的分工模式。

1、使用 ws 库启动 Node.js WebSocket 服务:const wss = new WebSocket.Server({ port: 8080 });

2、PHP 在关键操作后发送 HTTP 请求通知 Node.js:file_get_contents('http://localhost:3000/notify?event=order_created');

3、Node.js 接收通知后调用 wss.clients.forEach(client => client.send(...))

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

519

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

588

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

628

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3613

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

53

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

67

2026.01.13

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

45

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号