egg 整体架构源码分析及2个多月没更新的原因

本文探讨了Egg框架的运行机制,包括egg-bin、egg-scripts和egg-cluster的角色,以及它们如何协同启动和管理应用。作者分析了Egg在不同环境下的启动流程,并分享了在蚂蚁金服面试中对Egg核心源码的理解。文章旨在记录Egg应用的启动过程,帮助读者理解Egg的环境区分、配置和插件注入等核心概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个 egg 应用能运行起来,并不单纯的靠 egg 模块,这个是用过的同学都知道的,但是到底它是如何跑起来的呢,整体涉及到了多少个模块呢,这篇文章就是大概跟大家粗略分析这些了,另外长期没更新的原因有以下几点

  1. 元旦回来后我开始进行了蚂蚁金服的面试(为期一个月);
  2. 过年嘛,玩去了;
  3. 准备离职与入职(蚂蚁金服面试成功 => P6);

首先 egg 应用跑起来离不开下面几点

  • egg-bin(开发模式下)
  • egg-scripts (线上环境,其实 egg-bin 也是跑的 egg-scripts)
  • egg-cluster (由 egg-scripts 调用的,在其中涉及到 master-agent-worker 进程的分层以及各进程的进程守护与 IPC)
  • egg(不多说了,默认的 this.options.framework
  • egg-core(egg 模块继承的模块,进行插件及配置的注入以及继承于 KoaApplication 启动应用,在 egg-cluster 中调用)

由于涉及的东西太多,不是一篇文档可以讲完的,所以我在 github 中专门建了一个仓库用于撰写
YOLO 的 github

这里只放上一个概论,有兴趣的同学自己去看下吧,复杂程度由低到高如下

  • egg-bin
  • egg-scripts
  • egg
  • egg-core
  • egg-cluster
本文诞生的起因
  1. 在使用 egg 之后,首先大家都知道它是基于 koa 封装的一个企业级应用 web 框架,那么到底它是如何封装、如何启动、如何集群部署、如何停止多线程服务的呢
  2. 在蚂蚁金服的面试中也多次问到我是否看过 egg-core 的源码(我当时没看),这也侧面让我明白到其在内部的地位,因为我们都知道 egg 是在阿里内部经过大量实践后才经过处理后开源出来的,所以在这之后我花了一些时间去消化 egg-core 的源码,然后知道了 egg 跑起来是如何做环境区分的、如何根据环境变量去做配置、插件、全局中间件(在插件中判断)注入应用的,插件是如何作为一个单独应用被注入等
  3. 随后我发现在自己粗略分析的过程中其实也是通过多个入口去看的(因为我的学习习惯就是追本溯源),通过不同的入口区分不同的情况,比如本地开发跑的是 egg-bin 脚本,线上测试与生产跑的是 egg-scripts 脚本,前置步骤其实是较为繁琐的,看完后过2天我已经将核心忘的差不多了
针对上述问题的解决方案

遂有了这篇文章的诞生,旨在记录这个运行的大概过程,当然我也不保证自己写的会全是正确的,所以如果有错误希望大家指出,我会查看并仔细修改,共勉~

so,本文将从几个角度分析 egg 是如何运行起来的
  1. 开发环境入口 egg-bin
  2. 线上测试以及生产环境入口 egg-scripts
    • egg-scripts start
    • egg-scripts stop
    • 源码分析入口为 /egg-scirpts/summary.md(egg-scripts 解析大纲)
  3. egg-scripts 对于集群部署 cluster 模块的运用
    • egg-cluster(太特么多了,正在进行中…)
  4. egg-core
    • 如何进行环境区分
    • 配置注入(插件与 config 配置的注入)
    • 继承 KoaApplication 启动应用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值