【Swoole 的生命周期,文件描述符,协程数量,以及默认值】
目录
Swoole 的生命周期
Swoole 文件描述符(FD)缓存
Swoole设置协程的数量
Swoole 默认值
Swoole 是一个基于 PHP 的高性能网络通信引擎,它采用 C++ 编写,提供了协程和高性能的网络编程支持。Swoole 支持多种网络服务器和客户端模块,能够轻松快速地实现 TCP/UDP 服务、高性能 Web、WebSocket 服务、IoT、实时通信、游戏和微服务等,打破了 PHP 在传统 Web 领域的限制1。
Swoole 的生命周期
主要分为以下几个阶段:
-
初始化(PHP_MINIT_FUNCTION):当 PHP 启动时,会调用 Swoole 的初始化函数,用于设置全局状态和定义常量等3。
-
请求开始(PHP_RINIT_FUNCTION):每个 PHP 请求开始时,Swoole 会进行请求相关的初始化工作,如设置请求状态、注册关闭函数等3。
-
请求处理:在请求处理阶段,Swoole 可以利用其协程特性,以同步的方式编写异步代码,提高性能2。
-
请求结束(PHP_RSHUTDOWN_FUNCTION):请求结束时,Swoole 会进行资源的清理和释放,包括事件循环资源、服务器资源和协程资源等3。
-
关闭(PHP_MSHUTDOWN_FUNCTION):当 PHP 关闭时,Swoole 会执行清理工作,释放运行过程中的资源,避免资源泄露3。
-
信息(PHP_MINFO_FUNCTION):Swoole 还提供了一个函数用于打印关于模块的信息,如作者、版本等3。
Swoole 的设计目标是为了解决传统 PHP-FPM 模式并发慢的问题,通过常驻内存和协程机制来提高 PHP 应用的性能。它允许开发者以同步的方式编写代码,而 Swoole 在底层自动处理异步逻辑,降低了编程的复杂性2。
此外,Swoole 的事件循环和协程上下文切换都是内存读取,避免了 CPU 寄存器、堆栈以及系统内核态与用户态之间的切换,因此切换开销极小3。这使得 Swoole 在处理大量并发连接时表现出色,同时保持了较低的资源消耗。
Swoole 文件描述符(FD)缓存
默认的 100000 不是单个 worker 进程下的协程数目。实际上,这个数字是指 Swoole 服务器的文件描述符(FD)缓存大小,默认情况下,Swoole 会为每个 worker 进程分配一个大小为 100MB 的缓冲区来缓存数据。
在 Swoole 中,协程(Coroutine)是一种轻量级的线程,用于处理 I/O 密集型任务,而不会阻塞整个进程。协程的默认数量取决于你的 Swoole 服务器配置。Swoole 允许你配置每个 worker 进程的协程数量,这个数量可以根据你的应用需求和服务器性能进行调整。
PHP 开发者通常可以启动多个 worker 进程来提高并发处理能力。Swoole 通过 master-worker 模式来管理这些进程,其中:
- master 进程:负责接收客户端连接,并将连接分发给 worker 进程。
- worker 进程:实际处理业务逻辑,可以包含多个协程来并行处理 I/O 操作。
每个 worker 进程的协程数量可以在 Swoole 服务器的配置中设置,例如使用 Swoole\Server 的 set 方法:
$server->set(['worker_num' => 4, // 设置 worker 进程的数量'max_coroutine' => 10000, // 设置每个 worker 进程的协程数量
]);
在这个例子中,worker_num 表示 worker 进程的数量,而 max_coroutine 表示每个 worker 进程可以创建的协程的最大数量。根据你的应用场景和服务器资源,你可以调整这些值以获得最佳性能。
Swoole 的默认值为 100000,指的文件描述符缓存大小,而不是协程数量。
Swoole设置协程的数量
应该查看 Swoole 的配置项 max_coroutine。
max_coroutine 是 Swoole 协程模式下每个 worker 进程中可以创建的最大协程数量。这个值可以根据应用需求和服务器性能进行调整。协程数量的设置没有固定的范围,但通常受限于以下几个因素:
-
服务器内存:每个协程都需要分配一定的内存空间来存储其执行状态,包括局部变量、寄存器状态等。因此,服务器的可用内存是限制协程数量的一个重要因素。
-
操作系统限制:操作系统可能对单个进程可以打开的文件描述符数量有限制,这间接影响了协程的数量,因为每个协程都可能涉及到文件描述符的操作。
-
Swoole 配置:Swoole 允许你通过配置来设置协程的数量,但这个设置需要在合理的范围内,以避免因为协程过多导致的性能问题。
-
应用场景:I/O 密集型的应用可能需要更多的协程来充分利用 I/O 等待时间,而 CPU 密集型的应用则可能需要较少的协程,以避免过多的上下文切换和资源竞争。
-
性能测试:最佳的协程数量往往需要通过性能测试来确定,这涉及到对应用进行压力测试,找到最优的配置点。
通常,Swoole 的 max_coroutine 默认值可能在几千到几万之间,但具体的最佳值需要根据应用和服务器环境来确定。如果应用主要是 I/O 密集型,并且服务器有充足的内存资源,可以尝试增加协程的数量。但是,如果协程数量过多,可能会导致内存使用过高,或者因为频繁的上下文切换而降低性能。
在设置 max_coroutine 时,你也应该考虑设置 worker_num,即 worker 进程的数量。Swoole 的 worker 进程数量通常设置为 CPU 核心数的 1-4 倍,这样可以充分利用多核 CPU 的计算能力,同时避免进程之间的上下文切换开销。
最后,调整这些参数的最佳方法是进行实际的性能测试,根据测试结果来找到最适合应用的配置。
Swoole 默认值
hyperf官方文档有这么一段话最大协程数限制
对 Swoole Server 通过 set 方法设置 max_coroutine 参数,
用于配置一个 Worker 进程最多可存在的协程数量。因为随着
Worker 进程处理的协程数目的增加,其对应占用的内存也会随之增加,
为了避免超出 PHP 的 memory_limit 限制,
请根据实际业务的压测结果设置该值,Swoole 的默认值为 100000
( Swoole 版本小于 v4.4.0-beta 时默认值为 3000 ),
在 hyperf-skeleton 项目中默认设置为 100000。
Hyperf 框架的官方文档中提到的 max_coroutine 参数,是 Swoole 扩展的一个配置项,用于设置单个 worker 进程中可以创建的最大协程数量。这个参数的设置需要根据你的应用需求和服务器配置来决定。
文档中提到的 Swoole 默认值可能存在一些混淆,这里解释一下:
- Swoole 版本小于 v4.4.0-beta 时默认值为 3000:这意味着在 Swoole 4.4.0-beta 之前的版本中,如果没有显式设置
max_coroutine,其默认值是 3000。 - Swoole 的默认值为 100000:这可能是指在某些特定的环境或配置下,或者在 Hyperf 框架中,
max_coroutine的默认值被设置为 100000。这并不一定是 Swoole 扩展本身的默认值,而可能是 Hyperf 框架为了优化性能而做的默认配置。
Hyperf 框架是基于 Swoole 扩展开发的,它在 Swoole 的基础上提供了一些默认配置和优化。因此,当你在 Hyperf 中看到 max_coroutine 的默认值是 100000 时,这实际上是 Hyperf 框架的默认配置,而不是 Swoole 扩展本身的默认配置。
在实际使用中,你应该根据自己的应用场景和服务器性能来调整 max_coroutine 的值。如果应用是 I/O 密集型的,并且服务器有足够的内存,可能需要增加协程的数量。但是,如果协程数量过多,可能会导致内存使用过高,或者因为频繁的上下文切换而降低性能。
此外,memory_limit 是 PHP 的配置项,用于限制 PHP 脚本可以使用的最大内存。当设置 max_coroutine 时,需要确保总的协程内存使用不会超过这个限制,否则 PHP 脚本可能会因为超出内存限制而失败。
总之,关于 max_coroutine 的默认值,应该以你所使用的 Swoole 版本或框架的文档为准,并根据实际的业务需求和服务器配置来调整这个值。
相关文章:
【Swoole 的生命周期,文件描述符,协程数量,以及默认值】
目录 Swoole 的生命周期 Swoole 文件描述符(FD)缓存 Swoole设置协程的数量 Swoole 默认值 Swoole 是一个基于 PHP 的高性能网络通信引擎,它采用 C 编写,提供了协程和高性能的网络编程支持。Swoole 支持多种网络服务器和客户端…...
“不要卷模型,要卷应用”之高考志愿填报智能体
摘要:李总的发言深刻洞察了当前人工智能领域的发展趋势与核心价值所在,具有高度的前瞻性和实践性。“大家不要卷模型,要卷应用”这一观点强调了在当前人工智能领域,应该更加注重技术的实际应用而非单纯的技术竞赛或模型优化。个性…...
k8s离线部署芋道源码后端
目录 概述实践Dockerfilek8s部署脚本 概述 本篇将对 k8s离线部署芋道源码后端 进行详细的说明,对如何构建 Dockerfile,如何整合 Nginx,如何整合 ingress 进行实践。 相关文章:[nacos在k8s上的集群安装实践] k8s离线部署芋道源码前…...
图论·Day01
P3371 P4779 P3371 【模板】单源最短路径(弱化版) 注意的点: 边有重复,选择最小边!对于SPFA算法容易出现重大BUG,没有负权值的边时不要使用!!! 70分代码 朴素板dijsk…...
hutool ExcelUtil 导出导入excel
引入依赖 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.15</version></dependency>文件导入 public void savelist(String filepath,String keyname){ExcelReader reader Exce…...
打卡第7天-----哈希表
继续坚持✊,我现在看到leetcode上的题不再没有思路了,真的是思路决定出路,在做题之前一定要把思路梳理清楚。 一、四数相加 leetcode题目编号:第454题.四数相加II 题目描述: 给定四个包含整数的数组列表 A , B , C , …...
【Linux】WEB网站网络防火墙(WAF软件)Fail2ban:保护服务器免受恶意攻击的必备工具
随着互联网的迅速发展,服务器的安全性日益成为用户和管理员关注的焦点。恶意攻击者不断寻找机会侵入服务器,窃取敏感信息、破坏数据或者滥用系统资源。为了抵御这些威胁,许多安全工具应运而生,其中一款备受推崇的工具就是 Fail2ba…...
妙笔生词智能写歌词软件:创新助力还是艺术之殇?
在音乐创作日益普及和多样化的当下,各种辅助工具层出不穷,妙笔生词智能写歌词软件便是其中之一。那么,它到底表现如何呢? 妙笔生词智能写歌词软件(veve522)的突出优点在于其便捷性和高效性。对于那些灵感稍…...
力扣hot100-普通数组
文章目录 题目:最大子数组和方法1 动态规划方法2 题目:合并区间题解 题目:轮转数组方法1-使用额外的数组方法2-三次反转数组 题目:除自身以外数组的乘积方法1-用到了除法方法2-前后缀乘积法 题目:最大子数组和 原题链…...
深入浅出Transformer:大语言模型的核心技术
引言 随着自然语言处理(NLP)领域的不断发展,Transformer模型逐渐成为现代大语言模型的核心技术。无论是BERT、GPT系列,还是最近的T5和Transformer-XL,这些模型的背后都离不开Transformer架构。本文将详细介绍Transfor…...
MacOS隐藏文件打开指南
MacOS隐藏文件打开指南 方法一: 直接按下键盘上的【commandshift.】,这时候就可以在mac系统中就会自动显示隐藏的文件夹了 方法二: 在终端查看 ls -la...
grafana数据展示
目录 一、安装步骤 二、如何添加喜欢的界面 三、自动添加注册客户端主机 一、安装步骤 启动成功后 可以查看端口3000是否启动 如果启动了就在浏览器输入IP地址:3000 账号密码默认是admin 然后点击 log in 第一次会让你修改密码 根据自定义密码然后就能登录到界面…...
53-4 内网代理6 - frp搭建三层代理
前提:53-3 内网代理5 - frp搭建二级代理-CSDN博客 三级网络代理 在办公区入侵后,发现需要进一步渗透核心区网络(192.168.60.0/24),并登录域控制器的远程桌面。使用FRP在EDMZ区、办公区与核心区之间建立三级网络的SOCKS5代理,以便访问核心区的域控制器。 VPS上的FRP服…...
SQLite 命令行客户端 + HTA 实现简易UI
SQLite 命令行客户端 HTA 实现简易UI SQLite 客户端.hta目录结构参考资料 仅用于探索可行性,就只实现了 SELECT。 SQLite 客户端.hta <!DOCTYPE html> <html> <head><meta http-equiv"Content-Type" content"text/html; cha…...
TikTok小店推出“百万英镑俱乐部”,实力宠卖家!
TikTok Shop近期在英国市场重磅推出了“百万英镑俱乐部”激励计划,这一举措旨在通过一系列诱人福利,助力商家在TikTok平台上实现销售飞跃。该计划不仅彰显了TikTok Shop对于商家成长的深切关怀,更以实际行动诠释了“实力宠卖家”的承诺。 我…...
路径规划 | 基于蚁群算法的三维无人机航迹规划(Matlab)
目录 效果一览基本介绍程序设计参考文献 效果一览 基本介绍 基于蚁群算法的三维无人机航迹规划(Matlab)。 蚁群算法(Ant Colony Optimization,ACO)是一种模拟蚂蚁觅食行为的启发式算法。该算法通过模拟蚂蚁在寻找食物时…...
.Net C#执行JavaScript脚本
文章目录 前言一、安装二、执行 JavaScript 脚本三、与脚本交互四、JS 调用 C# 方法五、多线程使用总结 前言 ClearScript 是一个 .NET 平台下的开源库,用于在 C# 和其他 .NET 语言中执行脚本代码。它提供了一种方便和安全的方法来将脚本与应用程序集成,…...
企业应对策略:全面防御.DevicData-P-xxxxxx勒索病毒
引言 在数字化时代,网络安全已成为不可忽视的重要议题。随着互联网的普及,各种网络威胁层出不穷,其中勒索病毒以其独特的攻击方式和巨大的破坏性,给个人用户和企业带来了严重的经济损失和数据安全风险。在众多勒索病毒中ÿ…...
记一次mysql导出到达梦数据库
DM8管理工具 DM管理工具(官方)DBeaver - jdbc驱动 MySql迁移到DM8 使用官方DM数据迁移工具 新建迁移工程选择MySQL>DM填写mysql连接信息、添加dm连接信息执行 DM8数据脚本制作过程 使用DM管理工具 导出全部:进入对应模式>表>选…...
2024年高压电工证考试题库及高压电工试题解析
题库来源:安全生产模拟考试一点通公众号小程序 2024年高压电工证考试题库及高压电工试题解析是安全生产模拟考试一点通结合(安监局)特种作业人员操作证考试大纲和(质检局)特种设备作业人员上岗证考试大纲随机出的高压…...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...
令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...
协议转换利器,profinet转ethercat网关的两大派系,各有千秋
随着工业以太网的发展,其高效、便捷、协议开放、易于冗余等诸多优点,被越来越多的工业现场所采用。西门子SIMATIC S7-1200/1500系列PLC集成有Profinet接口,具有实时性、开放性,使用TCP/IP和IT标准,符合基于工业以太网的…...
TCP/IP 网络编程 | 服务端 客户端的封装
设计模式 文章目录 设计模式一、socket.h 接口(interface)二、socket.cpp 实现(implementation)三、server.cpp 使用封装(main 函数)四、client.cpp 使用封装(main 函数)五、退出方法…...
Xcode 16 集成 cocoapods 报错
基于 Xcode 16 新建工程项目,集成 cocoapods 执行 pod init 报错 ### Error RuntimeError - PBXGroup attempted to initialize an object with unknown ISA PBXFileSystemSynchronizedRootGroup from attributes: {"isa">"PBXFileSystemSynchro…...
DeepSeek越强,Kimi越慌?
被DeepSeek吊打的Kimi,还有多少人在用? 去年,月之暗面创始人杨植麟别提有多风光了。90后清华学霸,国产大模型六小虎之一,手握十几亿美金的融资。旗下的AI助手Kimi烧钱如流水,单月光是投流就花费2个亿。 疯…...
