0

0

不是很理解PHP的运行机制,求解

php中文网

php中文网

发布时间:2016-08-04 09:20:12

|

1233人浏览过

|

来源于php中文网

原创

像java、nodejs,应该都是在服务端持续运行的一个程序,这个程序会一直运行,会占用cpu,会占用内存,接到网络请求,就会处理。

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

而PHP似乎不是一个程序,更类似于html,只有打开的时候才会执行,当没有人访问php的服务时,php甚至一点点内存都不占,一点点cpu都不占,是这样吗?


如果是这样,那php不是很难封装数据库class?因为每个用户进来都要给他开一个进程,进程之间互不相通,A用户进来给他开一个数据库连接,B用户进来又要给他单独开数据库连接。那php不是在不断连接和断开数据库?用户多了之后,开销应该很大吧?


这也是导致php没有类似js的 setInterval 或者 setTimeout 函数的原因吗?

回复内容:

像java、nodejs,应该都是在服务端持续运行的一个程序,这个程序会一直运行,会占用cpu,会占用内存,接到网络请求,就会处理。

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

而PHP似乎不是一个程序,更类似于html,只有打开的时候才会执行,当没有人访问php的服务时,php甚至一点点内存都不占,一点点cpu都不占,是这样吗?


如果是这样,那php不是很难封装数据库class?因为每个用户进来都要给他开一个进程,进程之间互不相通,A用户进来给他开一个数据库连接,B用户进来又要给他单独开数据库连接。那php不是在不断连接和断开数据库?用户多了之后,开销应该很大吧?


这也是导致php没有类似js的 setInterval 或者 setTimeout 函数的原因吗?

以PHP-FPM为例(类似Apache MOD_PHP)说说PHP的运行机制.
首先,PHP-FPM是一个C实现的多进程FastCGI服务.
每个PHP-FPM工作进程都内置了PHP解释器,不依赖PHP-CGI,都支持后台常驻,比如配置:

nginx.conf: 访问io.php的请求都交给监听9001的PHP-FPM进程池处理
location = /io.php {
    include fastcgi_params;
    fastcgi_pass 127.0.0.1:9001;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}

php-fpm: 正常脚本由静态www池处理,阻塞脚本由动态io池处理
[www]
;名为www的进程池监听9000端口,常驻进程数量为固定4个
listen = 127.0.0.1:9000
pm = static
pm.max_children = 4
[io]
;名为io的进程池监听9001端口,进程数常驻4个,最大8个
listen = 127.0.0.1:9001
pm = dynamic
pm.max_children = 8
pm.start_servers = 4
pm.min_spare_servers = 4
pm.max_spare_servers = 4

PHP-FPM主进程就是用来管理这些工作进程的,比如一个工作进程被杀死了,立马重建一个.
PHP-FPM提供给了pm.status_path来通过浏览器查看整套PHP-FPM服务的工作状态.
像执行超时放弃,处理指定请求数后自动重启工作进程,慢日志记录(找出耗时的文件和函数)都支持.

而且开启持久连接后,每个PHP-FPM工作进程都能保持一个到MySQL的长连接不释放,避免重复连接数据库.
比如下图展示的是2个PHP-FPM进程跟MySQL建立的2个长连接:
不是很理解PHP的运行机制,求解
另外,针对Memcached和Redis的PECL扩展也都实现了持久连接的功能.

上面说了PHP-FPM的体系,下面就该说说PHP脚本在PHP-FPM体系下的生命周期.
PHP脚本里的量(包括全局变量)的生命周期只存在于一次请求内,请求处理完成,PHP-FPM就自动释放资源.
一次请求释放一次资源,这种内存释放是非常彻底的,PHP基于引用计数的GC甚至都还没发挥作用程序就已经结束了.
这里的释放资源指的是脚本里控制的资源,而不会干预到PHP-FPM常驻进程,不会让PHP-FPM进程关闭,也不能让PHP-FPM关闭到MySQL的持久连接,PHP-FPM只负责输入PHP脚本,执行PHP操作,如果加入了ZendOpcache支持,还可以把解析PHP脚本生成的opcode全部缓存到内存里共下次直接解释执行.PHP7中还支持用opcache.file_cache导出脚本opcode实现源代码保护.

PHP的一些常识:
数据库连接池: PHP持久连接就是天然的透明的无需程序干预的连接池,支持MySQL/Memcached/Redis等.
内存常驻: PHP-FPM进程,ZendOpcache缓存的脚本的opcode,鸟哥开发的Yac都是内存常驻的.
垃圾回收: PHP-FPM一次请求释放一次资源的运行模式,削弱了基于引用计数的GC的作用.

最后,CLI下工作的PHP守护进程服务比如Swoole/WorkerMan才跟Java/Node之类相似.

虽然我已经下班了,看到你这个提说PHP是类似html我忍不了。PHP功能是html无法比拟的好不好,就拿你说的连接数据库的例子来说,html能连接数据吗?能读取数据库内容吗?不能吧!还有你说多个用户来访问每个用户都要开一个数据库连接,你这样太小看PHP了。封装一个数据库连接类很简单很简单,这些我就不贴code了。PHP手册每种数据库扩展都有介绍也有事例,你可以自己做参考。你既然提到java那肯定也知道单例模式吧!PHP封装好一个数据库连接类设置单例模式就可以实现数据连接静态化。不管多少用户来访问直接调用一下就可以不是你说的多个用户来访问就开多个进程。还有你提到的setIntervalsetTimeout不就是定时执行吗!PHP也可以的啊!首先定义好PHP要实现的功能,然后通过在服务器上设置crontab就可以了,参数自己设置就行,或者还有php-fpm。还有等等等的功能我就不罗列了,也没整理答案格式你先凑活着看。我得下班走人了,有问题咱明天继续讨论

总之,PHP是一门很好很好的语言,功能很强大……而且还在不断的发展壮大中……易学易懂啊!兄弟

PHP不能常驻内存,每一个HTTP请求开后,连接数据库,等请求结束了,数据库连接 和 各种变量都释放掉了。

你总体上的理解是对的,但的不是所有的语言都是java那种常驻内存的,python,go,c都不是。PHP也确实没有链接池的概念,进程执行完就好释放掉,不会留着给其他进程用

网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版
网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版

  websenB2B是一套经过完善设计的B2B行业网站程序,是windows nt系列环境下最佳的B2B行业网产站解决方案。精心设计的架构与功能机制,适合从个人到企业各方面应用的要求,为您提供一个安全、稳定、高效、易用而快捷的行业网站商务系统。分普及版和商业版等不同版本。一、网胜B2B电子商务系统SP6.2蓝色风格普及版本升级功能说明:1、邮件群发功能:可以选择某一级别的会员,并放入支持html

下载

给你 《深入理解 PHP 内核》第二章第一节的内容链接:

http://www.php-internals.com/...

你的疑惑,只是因为你只看到了表面。

如果你用过 swoole,我想你肯定不会提出这种问题。

呃,你当php-fpm没到。。。

而PHP似乎不是一个程序,更类似于html

PHP只是可以嵌入到HTML中,但跟HTML是天壤之别,PHP有很多扩展可以做不同的事情,HTML能吗?

只有打开的时候才会执行,当没有人访问php的服务时,php甚至一点点内存都不占,一点点cpu都不占,是这样吗?

PHP主要有两种运行方式(除了CLI):
1.Apache为代表的mod_php,这时工作是交给Apache处理了。
2.Nginx/Lighttpd用的php-fpm(fastcgi进程管理器),这个是常驻的守护进程。
所以说,怎么可能不占CPU和内存?

如果是这样,那php不是很难封装数据库class?因为每个用户进来都要给他开一个进程,进程之间互不相通,A用户进来给他开一个数据库连接,B用户进来又要给他单独开数据库连接。那php不是在不断连接和断开数据库?用户多了之后,开销应该很大吧?

以MySQL为例,如果连接时选择pconnect(持久连接)的话,下次就会直接使用已存在的连接,不会关闭连接。
PDO也有长连接选项。

这也是导致php没有类似js的setInterval或者setTimeout函数的原因吗?

PHP是有延时函数(如sleep())的哦,而且精度比JS的高太多太多了(微秒级别)。

好热闹啊。 @ivanilla 的回答与评论包含好多信息,感谢。

其实我认为针对楼主的问题,PHP的运行机制就是解释执行脚本。PHP是为中小型网站提供服务端支持的脚本语言,在开发速度与运行效率上具有良好的平衡,这是它成功的原因。

所以楼主的其它观点就没啥看头了,连争论都无意义,如果PHP拥有了你想像的那些东西,这个语言也就没人用了,大家干脆还是用java好了。

楼主对PHP的一些基础知识不了解,应该是刚开始接触PHP。简单来说PHP可以以两种模式运行,一种是脚本方式,如在 shell 里执行 php xxx.php;一种是楼主理解的有网络请求才启动运行(不是十分贴切),有编译成apache的扩展方式,也有fast-cgi方式。apache的mod_php方式就是来一个请求起一个进程执行,效率底下,相应的有各种参数优化等。而fast-cgi则要高效得多,具体的楼主可以翻看相应的手册并实际操作一下。

楼上几位真有耐心

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

php

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

616

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

194

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

91

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

20

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

54

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

598

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

56

2026.02.12

热门下载

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

精品课程

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

共137课时 | 12万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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