分析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. Aria2+百度网盘 无限制的下载神器

    Aria2是一款免费开源跨平台且不限速的多线程下载软件,Aria2的优点是速度快.体积小.资源占用少:支持 HTTP / FTP / BT / Magnet 磁力链接等类型的文件下载:支持 Win.M ...

  2. CIFAR10数据可视化

    一.数据准备 下载cifar-10-binary.tar.gz并解压,其中有多个bin文件,现对data_batch_1.bin进行可视化. 二.数据说明 该二进制文件存储的有10000张32X32的 ...

  3. 【java】接口

    class :用于定义类interface:用于定于接口 接口定义时,特点:1.接口中常见定义:常亮和抽象方法2.接口中的成员都有固定修饰符(如果没有会被隐式添加) 常量:public static ...

  4. springboot+mockito 异常解决方案

    系统启动的异常日志如下 javax.net.ssl.* java.lang.IllegalStateException: Failed to load ApplicationContext at or ...

  5. 【剑指offer】广度优先遍历二叉树

    问题:从上往下打印出二叉树的每个节点,同层节点从左至右打印. *思路:先用队列存放树的根结点.每次出队一个结点,将结点非空的左右孩子分别入队.重复此过程,直到队列为空. import java.uti ...

  6. keil5 MDK warning:registered ARM compiler version not found in path

    重装 打开keil5弹出窗口: warning:registered ARM compiler version not found in path... 解决: 增加系统环境变量 ARMCC5LIB ...

  7. 2017-2018-2 20165312 课下选做 MySort

    2017-2018-2 20165312 课下选做 MySort 题目描述 模拟实现Linux下Sort -t : -k 2的功能,参考 Sort的实现. import java.util.*; pu ...

  8. GraphicsMagick命令

    [ convert | identify | mogrify | composite | montage | compare | display | animate | import | conjur ...

  9. Python · 进度条

    (这里是本章会用到的 GitHub 地址) 我实现的这个进度条可能是可以当做一个第三方库来使用的(这个人好自大,啧),它支持记录并发程序的进度且损耗基本只来源于 Python 本身 先来看看我们的进度 ...

  10. IDEA常用快捷键,收藏以备后用

    IntelliJ Idea 常用快捷键列表 Ctrl+Shift + Enter,语句完成“!”,否定完成,输入表达式时按 “!”键Ctrl+E,最近的文件Ctrl+Shift+E,最近更改的文件Sh ...