echo框架的使用. 见wiki https://echo.labstack.com/guide
- echo.New
- 初始化server (http & tls)
- 初始化日志 & 颜色 color
- 设置默认 错误处理 DefaultHTTPErrorHandler 和默认的binder(用于request的参数解析) DefaultBinder
- 设置日志error级别 & 设置标准输出 StdLogger
- 新建一个 sync.pool - pool的概念可以参考 https://studygolang.com/articles/3506 (用于echo.context)
- 初始化路由 NewRouter
- 注册中间件 所有的中间件 先注册的先执行. ( 底层执行时是从尾遍历到头的 ) 这些按下面的阶段依次执行.
- echo.Pre(mmw) // 在路由之前执行, 添加进 e.premiddleware
- echo.Use(mmw) // 在路由之后执行, 添加进 e.middleware
- group.Use(mmw) // 组粒度的
- router.Any(e, handler, mmws) // 最后是路由匹配时注册的 使用了 path 包处理路径
- 路由注册
- 组(group)路由注册 g.echo.Any
- method + path
- 最终注册到 e.router 中, 其实一颗树.
- http server
- ECHO#ServeHTTP 处理
| 初始化 context
| e.premiddleware 如果pre不为空则获取handler之后串联 pre 否则直接串联 mx (先pre -> 查找路由匹配 -> 执行mw)
| 释放 context
整体来说这个框架还是很轻量级的 .
这个框架的核心部分
- mw 利用 匿名函数实现 mw的嵌套. 且mw分为了 三个粒度的.
- 路由的插入与匹配, 使用了redix树. 如: https://blog.csdn.net/petershina/article/details/53313624
以下简单的看下echo怎么使用的radix树.
In computer science, a **trie**, also called **digital tree**, **radix tree** or **prefix tree**
- node定义
node struct {
kind kind
label byte
prefix string
parent *node
children children
ppath string // pristine path 原始的路径
pnames []string // param names
methodHandler *methodHandler
}
- 插入 Router.insert
- 注册一条静态路径 无 ":" & 无 "*"
r.insert(method, path, h, skind, ppath, pnames)