分析easyswoole源码

1以启动为例
//检查是否已经安装
installCheck();//检查锁文件是否存在,不存在结束
//启动服务
serverStart
showLogo();//显示logo
$conf = Conf::getInstance();//获取config单例
$inst = Core::getInstance()->initialize();//获取Core(核心类)的单例并且initialize
//这一步干了这些事情
//__construct() Core的构造函数进行了这些操作
defined('SWOOLE_VERSION') or define('SWOOLE_VERSION',intval(phpversion('swoole')));//定义了swoole的版本
defined('EASYSWOOLE_ROOT') or define('EASYSWOOLE_ROOT',realpath(getcwd()));//定义了es的root目录
//加载事件函数(里面有frameInitialize,mainServerCreate,onRequest,afterAction的回调函数)
if(file_exists(EASYSWOOLE_ROOT.'/EasySwooleEvent.php')){
require_once EASYSWOOLE_ROOT.'/EasySwooleEvent.php';
}
$this->sysDirectoryInit();
这一步干了这些事情
$tempDir = Config::getInstance()->getConf('TEMP_DIR');//获取config配置的TEMP_DIR设置(在系统根目录Config.php下'TEMP_DIR'=>null,若不配置,则默认框架初始化)
if(empty($tempDir)){
Config::getInstance()->setConf('TEMP_DIR',EASYSWOOLE_ROOT.'/Temp');//会初始化为根目录下的Temp目录
$tempDir = EASYSWOOLE_ROOT.'/Temp';
} $logDir = Config::getInstance()->getConf('LOG_DIR');//获取config配置的LOG_DIR设置(在系统根目录Config.php下'LOG_DIR'=>null,若不配置,则默认框架初始化)
if(empty($logDir)){
Config::getInstance()->setConf('LOG_DIR',EASYSWOOLE_ROOT.'/Log');//会初始化为根目录下的Log目录
$logDir = EASYSWOOLE_ROOT.'/Temp';
} Config::getInstance()->setConf('MAIN_SERVER.SETTING.pid_file',$tempDir.'/pid.pid');//在config目录下设置pid.pid的保存路径,设置在Temp目录下
Config::getInstance()->setConf('MAIN_SERVER.SETTING.log_file',$logDir.'/swoole.log');//在config目录下设置swoole.log的保存路径,设置在Log目录下 //initialize做了这些事情
//Di是一个容器,里面可以保存对象,回调函数,和类名以及其他
Di::getInstance()->set(SysConst::VERSION,'2.1.2');//保存当前es的版本号
Di::getInstance()->set(SysConst::HTTP_CONTROLLER_MAX_DEPTH,3);//这一句不晓得3的作用
EasySwooleEvent::frameInitialize();//在上面提到的加载事件函数方法中会执行框架初始化的回调函数date_default_timezone_set('Asia/Shanghai');这里框架是设置了当前的时区
$this->errorHandle();
//这里注册了框架的错误处理机制
$conf = Config::getInstance()->getConf("DEBUG");//判断是否开启了debug模式,如果没开启直接不注册异常处理机制,系统会由php抛出异常
if(!$conf){
return;
}
ini_set("display_errors", "On");
error_reporting(E_ALL | E_STRICT);
$userHandler = Di::getInstance()->get(SysConst::ERROR_HANDLER);//会去系统配置文件中是否有用户自定义的错误处理函数,在系统vendor\easyswoole\easyswoole\src\Core\Component\SysConst.php中设置为const ERROR_HANDLER = 'ERROR_HANDLER';
if(!is_callable($userHandler)){//如果is_callable=false(不可调用的函数,会自己注册一个userHandler)
$userHandler = function($errorCode, $description, $file = null, $line = null){
Trigger::error($description,$file,$line,$errorCode);//其实userHandler和shutdown注册的函数都会调用Trigger::error,如果没有配置具体的处理方法的话,会默认 Logger::getInstance()->log($debug,'debug');Logger::getInstance()->console($debug,false);就是在LOG_DIR创建了一个日志记录错误同时控制台输出错误
};
}
set_error_handler($userHandler);//设置用户的函数 (error_handler) 来处理脚本中出现的错误。这个函数一般和trigger_error一起使用,抛出用户级别错误然后让$userHandler来捕获 $func = Di::getInstance()->get(SysConst::SHUTDOWN_FUNCTION);//会去系统配置文件中是否有注册一个会在php中止时执行的函数,在系统vendor\easyswoole\easyswoole\src\Core\Component\SysConst.php中设置为const SHUTDOWN_FUNCTION = 'SHUTDOWN_FUNCTION';
if(!is_callable($func)){//如果is_callable=false(不可调用的函数,会自己注册一个func)
$func = function ()use($conf){
$error = error_get_last();
if(!empty($error)){
Trigger::error($error['message'],$error['file'],$error['line']);
}
};
}
register_shutdown_function($func);
$version = \EasySwoole\Core\Component\Di::getInstance()->get(\EasySwoole\Core\Component\SysConst::VERSION);
echo "\n\e[31mEasySwoole\e[0m framework \e[34mVersion {$version}\e[0m\n\n";//在这个文档的38行保存的es版本号
// listen host set
if (isset($options['ip'])) {
$conf->setConf("MAIN_SERVER.HOST", $options['ip']);//在config目录下设置MAIN_SERVER.HOST;'HOST'=>'0.0.0.0',
}
showTag('listen address', $conf->getConf('MAIN_SERVER.HOST'));//showTag是一种包装的echo
if (!empty($options['pid'])) {//这个框架默认是为空的,因为swoole的server启动会自己创建
$pidFile = $options['pid'];
$conf->setConf("MAIN_SERVER.SETTING.pid_file", $pidFile);
} // worker num set
if (isset($options['workerNum'])) {//设置task数
$conf->setConf("MAIN_SERVER.SETTING.worker_num", $options['workerNum']);//在config目录下设置MAIN_SERVER.SETTING.worker_num;'worker_num'=>8
}
showTag('worker num', $conf->getConf('MAIN_SERVER.SETTING.worker_num')); // run at user set
//这个就是设置当前脚本的执行用户,我是自己的虚拟机,就是用root用户启动的
$user = get_current_user();
if (isset($options['user'])) {
$conf->setConf("MAIN_SERVER.SETTING.user", $options['user']);
$user = $conf->getConf('MAIN_SERVER.SETTING.user');
}
showTag('run at user', $user);
// daemonize set
$label = 'false';
//设置是否daemonize,守护进程模式
if (isset($options['d'])) {
$conf->setConf("MAIN_SERVER.SETTING.daemonize", true);
$label = 'true';
}
showTag('daemonize', $label);
// cpuAffinity set
if (isset($options['cpuAffinity'])) {
$conf->setConf("MAIN_SERVER.SETTING.open_cpu_affinity", true);
}
showTag('debug enable', $conf->getConf('DEBUG') ? 'true' : 'false');//输出配置的debug模式是否开启
showTag('swoole version', phpversion('swoole'));//输出当前swoole的版本
showTag('swoole pid', getmypid());//获取当前启动进程的pid $inst->run();//这里是核心。下篇文档进行分析

一 分析easyswoole源码(启动服务)的更多相关文章

  1. 二 分析easyswoole源码(启动服务)

    前文连接,阅读的时候最好参照EasySwoole2.1.2的源码 $inst->run();//启动服务 这里实际调用的是Core的start方法ServerManager::getInstan ...

  2. 四 分析easyswoole源码(启动服务&Cache组件原理)

    前文提到的在系统设置Cache组件 Cache::getInstance()的时候,会去调用processManager去创建Cache的进程,然后以管道通信的方式进行设置缓存和获取缓存. Cache ...

  3. 三 分析easyswoole源码(启动服务&TableManager,略提及Cache工具的原理)

    前文连接,讲了es是如何启动swoole服务的. 里面有一个工具类TableManager.这个类为了处理进程间数据共享.是对swoole_table的一层封装swoole_table一个基于共享内存 ...

  4. Netty源码解析---服务端启动

    Netty源码解析---服务端启动 一个简单的服务端代码: public class SimpleServer { public static void main(String[] args) { N ...

  5. k8s client-go源码分析 informer源码分析(2)-初始化与启动分析

    k8s client-go源码分析 informer源码分析(2)-初始化与启动分析 前面一篇文章对k8s informer做了概要分析,本篇文章将对informer的初始化与启动进行分析. info ...

  6. 【一起学源码-微服务】Nexflix Eureka 源码十:服务下线及实例摘除,一个client下线到底多久才会被其他实例感知?

    前言 前情回顾 上一讲我们讲了 client端向server端发送心跳检查,也是默认每30钟发送一次,server端接收后会更新注册表的一个时间戳属性,然后一次心跳(续约)也就完成了. 本讲目录 这一 ...

  7. 【一起学源码-微服务】Nexflix Eureka 源码十三:Eureka源码解读完结撒花篇~!

    前言 想说的话 [一起学源码-微服务-Netflix Eureka]专栏到这里就已经全部结束了. 实话实说,从最开始Eureka Server和Eureka Client初始化的流程还是一脸闷逼,到现 ...

  8. 【一起学源码-微服务】Eureka+Ribbon+Feign阶段性总结

    前言 想说的话 这里已经梳理完Eureka.Ribbon.Feign三大组件的基本原理了,今天做一个总结,里面会有一个比较详细的调用关系流程图. 说明 原创不易,如若转载 请标明来源! 博客地址:一枝 ...

  9. [源码分析] 从源码入手看 Flink Watermark 之传播过程

    [源码分析] 从源码入手看 Flink Watermark 之传播过程 0x00 摘要 本文将通过源码分析,带领大家熟悉Flink Watermark 之传播过程,顺便也可以对Flink整体逻辑有一个 ...

随机推荐

  1. Java面试题 corejava(二)

    65.JAVA 语言如何进行异常处理,关键字:throws,throw,try,catch,finally分别代表什么意义?在try 块中可以抛出异常吗?[基础] 答:Java 通过面向对象的方法进行 ...

  2. PAT 乙级 1092 最好吃的月饼 (20 分)

    1092 最好吃的月饼 (20 分) 月饼是久负盛名的中国传统糕点之一,自唐朝以来,已经发展出几百品种. 若想评比出一种“最好吃”的月饼,那势必在吃货界引发一场腥风血雨…… 在这里我们用数字说话,给出 ...

  3. 静态初始化块和main方法哪个先被执行?

    直接看代码 public class BlockAndMain { public static void main(String[] args) { System.out.println(" ...

  4. [UE4]Tree View

    类似List View,但Tree View要求提供树形结构的数据.Tree View和Tile View都是继承自List View 一.创建一个名为“TreeEntry”的UserWidget,添 ...

  5. html/css/js-个人容易忘的一些属性

    1.当div里面的文字超过给定div给定的宽度,div里面的文字自动换行 word-break:break-all:会截断该行最后的单词 word-wrap:break-word:不会截断,该行长度最 ...

  6. 采用link方式解决zabbix对于备份监控和ORACLE日志监控由于路径不统一的问题

    #对于备份监控和ORACLE日志监控由于路径不统一,我们可以采用link的方式如:#ln -s 原路径 新路径(/zabbix/logs)#新路径统一放在/zabbix/logs下具体看模板指定. # ...

  7. java中将表单转换为PDF

    经过网上搜索大概有三种方式:PDF模板数据填充,html代码转换pdf,借用wkhtmltopdf工具 一 .PDF模板数据填充 1.新建word,在word中做出和表单一样的布局的空表单,然后另存为 ...

  8. Http的那些事: Content-Type

    Content-Type 无疑是http中一个非常重要的属性了, request 中可以存在, 也可以不存在( request的Content-Type 默认是 */*, 实际上呢, 如果不存在Con ...

  9. 微信调用itchat库 实现发消息

    import itchat,timefrom itchat.content import * itchat.auto_login(enableCmdQR=-1)while True: for i in ...

  10. Mysql 8.0修改密码

    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密码';