workerman源码分析之启动过程详解
下面由workerman/" target="_blank">workerman教程栏目给大家介绍workerman源码分析之启动过程,希望对需要的朋友有所帮助!
workerman
版本:3.1.8(linux)
模型:GatewayWorker(Worker模型可与之类比)
注:只贴出讲解部分代码,出处以文件名形式给出,大家可自行查看
workerman最初只开发了Linux版本,win是后来增加的,基于命令行模式运行(cli)。
多进程模型
工作进程,Master、Gateway和Worker,Gateway主要用于处理IO事件,保存客户端链接状态,将数据处理请求发送给Worker等工作,Worker则是完全的业务逻辑处理,前者为IO密集型,后者为计算密集型,它们之间通过网络通信,Gateway和Worker两两间注册通信地址,所以非常方便的进行分布式部署,如果业务处理量大可以单纯的增加Worker服务。
它们有一个负责监听的父进程(Master),监听子进程状态,发送 signal 给子进程,接受来自终端的命令、信号等工作。父进程可以说是整个系统启动后的入口。
启动命令解析
既然以命令模式(cli)运行(注意与 fpm 的区别,后者处理来自网页端的请求),就必然有一个启动脚本解析命令,譬如说3.x版本(之前默认为daemon)新增一个 -d 参数,以表示守护进程运行,解析到该参数设置 self::$daemon = true, 随后fork子进程以脱离当前进程组,设置进程组组长等工作。
这里有两个非常重要的参数 $argc 和 $argc,前者表示参数个数,后者为一个数组,保存有命令的所有参数,比如:sudo php start.php start -d,$argv就是 array( [0]=>start.php, [1]=>start, [2]=>-d ),而解析主要用到$argv。
启动主要执行下面步骤:
1、包含自动加载器 Autoloader ,加载各 Application 下启动文件;
2、设置 _appInitPath 根目录;
3、解析,初始化参数,执行相应命令。
下面是具体实现(workerman/worker.php):
public static function parseCommand() { // 检查运行命令的参数 global $argv; $start_file = $argv[0]; // 命令 $command = trim($argv[1]); // 子命令,目前只支持-d $command2 = isset($argv[2]) ? $argv[2] : ''; // 检查主进程是否在运行 $master_pid = @file_get_contents(self::$pidFile); $master_is_alive = $master_pid && @posix_kill($master_pid, 0); if($master_is_alive) { if($command === 'start') { self::log("Workerman[$start_file] is running"); } } elseif($command !== 'start' && $command !== 'restart') { self::log("Workerman[$start_file] not run"); } // 根据命令做相应处理 switch($command) { // 启动 workerman case 'start': if($command2 === '-d') { Worker::$daemonize = true; } break; // 显示 workerman 运行状态 case 'status': exit(0); // 重启 workerman case 'restart': // 停止 workeran case 'stop': // 想主进程发送SIGINT信号,主进程会向所有子进程发送SIGINT信号 $master_pid && posix_kill($master_pid, SIGINT); // 如果 $timeout 秒后主进程没有退出则展示失败界面 $timeout = 5; $start_time = time(); while(1) { // 检查主进程是否存活 $master_is_alive = $master_pid && posix_kill($master_pid, 0); if($master_is_alive) { // 检查是否超过$timeout时间 if(time() - $start_time >= $timeout) { self::log("Workerman[$start_file] stop fail"); exit; } usleep(10000); continue; } self::log("Workerman[$start_file] stop success"); // 是restart命令 if($command === 'stop') { exit(0); } // -d 说明是以守护进程的方式启动 if($command2 === '-d') { Worker::$daemonize = true; } break; } break; // 平滑重启 workerman case 'reload': exit; } }
- js如何生命list
- oracle启动失败
- AI新革命GPT4中文版,思维···
- 深圳SEO实战技巧分享
- nginx服务器多站点怎么配置
- linux中source命令怎···
- Kaibanjs中使用Make···
- 什么是SEO自然优化?提升网站···
- 去AI痕迹:如何让智能科技融入···
- SEO优化,快速提升排名,引流···
- 如何打造一个完美的个人网站?,···
- 泰州网站建设如何优化SEO提升···
- 使用WordPress搭建商城···
- 织梦登陆后台卡死无法进入怎么办
- 百度快照更新迅速
- 网络营销方法主要有哪几种
- 行业关键词搜索:提升业务精准度···
- 网店SEO,关键词优化秘籍
- 如何分析网络流量:全面网络安全···
- docker如何查看报错?
- 网络客服,沟通桥梁,服务先锋
- 磁力搜·快搜宝
- 三级分销系统的作用有哪些
- SEO快排是什么?让你的网站迅···
- 淘宝寄件支持众邮快递吗?
- 品牌策划,创意营销专家
- 移动Web端提升转化率的关键策···
- 赫章SEO专家,高效优化服务
- “SEO高效推广,助力品牌腾飞···
- 免费SEO编辑器:提升网站排名···
- OpenAI官网:AI革命的前···
- js如何引入mysql
- 潍坊网站定制,优帮云助力企业数···
- 聊聊laravel的在线安装模···
- linux中的lib文件夹在哪
- 巧用产品SEO关键词,双提升流···
- 实例讲解Laravel框架中进···
- 网页速成神器,一触即达!
- 如何通过优化网站排名提升流量和···
- Nginx - 最小配置
- 域名注册扫描:抢占互联网风口,···
- 网站及时更新数据信息,提升用户···
- SEO优化企业网站,提升流量与···
- 腾讯云一键建站如何快速生成个性···
- 如何寻觅本地抖音代运营?
- 大连网页设计:创意与技术的完美···
- 拼多多零食能放心购买吗?
- 电商爆款打造,精准营销,快速变···
- 天猫国际正品保障,官网入口如何···
- 除了wordpress还有什么