GO——与PHP的并发对比

背景

go比php可支持的并发数更高,为什么

目标

分析点:

  • 系统的并发瓶颈
  • go语言的并发瓶颈
  • php语言的并发瓶颈
系统并发

参考:https://juejin.cn/post/6844904025553534990

  • 提到并发,我们这里指的是web服务
  • web系统的第一层,是nginx
  • web系统的并发瓶颈一般在DB上
go和php并发对比
  • 语言
    • go是编译性,直接生成可执行的字节码
    • php是解释性,执行时需要动态解析
      • fpm可以设置缓存解析后的字节码
  • 线程与协程
    • fpm是多进程单线程
    • go是利用协程提高并发
      • GPM中,P是线程级别的,P调用G,G是协程级别的
  • 切换
    • fpm单进程阻塞之后,内核会去处理其他的,这里是进程切换
    • go的goroutine阻塞之后,P会取寻找其他G来执行,一般不会发生线程切换
  • 内存
    • 一个php-fpm进程占20M
    • go的协程内存是kb级别的

记忆点:fpm进程和gorotine协程,资源消耗、切换、阻塞情况

附录

fpm

参考:https://www.php.cn/php-weizijiaocheng-455614.html

  • php+nginx工作流程
    • nginx接到请求
    • nginx转发给php
    • php的fastcgi的master收到请求
      • cgi只有一个php进程,它读取php.ini的配置,启动,并服务
      • fastcgi
        • 有多个进程,master进程读取配置,启动,后续的worker进程无需再次读取配置
        • master把请求给worker进程
        • worker进程服务
    • nginx并返回
  • fpm是用来管理fastcgi的进程的
相关推荐
梦想三三14 分钟前
【PYthon词频统计与文本向量化】苏宁易购评论分析实战
开发语言·python
AI人工智能+电脑小能手16 分钟前
【大白话说Java面试题 第93题】【Mysql篇】第23题:从查找速度来看,聚集索引和非聚集索引哪个更快?
java·开发语言·数据库·mysql·面试
Cheng小攸1 小时前
入侵检测环境部署
开发语言·php
我是唐青枫1 小时前
Java MyBatis-Flex 实战指南:从 BaseMapper 到 QueryWrapper 的轻量 ORM 用法
java·开发语言·mybatis
ShyanZh2 小时前
Markitdown 多格式文档智能解析实战指南
开发语言·c#
一只专注api接口开发的技术猿2 小时前
OpenClaw 对接淘宝商品 API,低成本实现全天候选品监控|附可运行 Python 实操代码
大数据·开发语言·数据库·python
xingpanvip2 小时前
星盘接口开发文档:马盘次限盘接口指南
android·开发语言·python·php·lua
FBI HackerHarry浩2 小时前
第二阶段Day07【Python生成器、yield关键字、property、正则表达式】
开发语言·python·正则表达式
iiiiyu2 小时前
IO流(二)
java·开发语言·数据结构·编程语言
白露与泡影2 小时前
牛客网大厂Java面试题全集(2026版,附答案)
java·开发语言