香香编程Go知识地图
2023-07-06 00:09:02 0 举报
AI智能生成
为你推荐
查看更多
香香编程Go知识地图
作者其他创作
大纲/内容
值类型与引用类型
简单数据结构
结构体是否可以比较?
结构体
空接口是一种特殊接口
接口
什么是泛型
有哪些使用场景
泛型
基础数据结构
两者有什么关系
切片是如何扩容的
append函数的使用细节
切片与数组
有哪些常见的哈希函数
哈希函数
哈希冲突
Map的原理
开放寻址法
拉链法
Map是如何扩容的
并发安全的Map
Map
有什么用途
单向通道
使用通道的注意事项
什么时候会阻塞
操作一个已关闭的通道会发生什么
空struct{}的作用
双向通道
通道
重点数据结构
IS
AS
New
常用函数
如何避免出现大量的if err != nil
如何理解 Error is Value
常见问题
Error
底层数据结构
错误链的组织方式
panic与协程的关系
Panic
defer 的底层原理
defer 与协程的关系
defer
异常处理
go routine 协程
协程通信
协程编排
并发安全
并发编程
Http
Websocket
网络编程
性能排查
垃圾回收
内存分配
协程调度
编译
底层原理
语言
Engine是Gin框架的核心,所有代码都集成在这个结构体里
Router 路由
Middleware 中间件
Context 上下文
输入输出
其他
将Engine结构,会得到以下几个模块
New()
Default()
启动
普通关闭
优雅关闭
关闭
Engine的启动和优雅关闭
关键字段详解
Engine
数组用来存储请求类型:GET,POST,DELETE等
前缀树用来存储具体的路径
前缀树的叶子节点上存的有函数链
数据结构:数组+前缀树
/book/info
静态路由
/book/:id
/book/:id/info
动态路由
可以配置特殊作用的路由
可以存储较多类型的路由
节省空间,本质相当提取公共项
查询效率上比MAP低一些
数据结构上不如MAP轻巧,简单
敏感词检索
省市地区的检索
搜索框推荐信息
前缀树的其他使用场景
前缀树的特点
Handlers 一个函数链,底层是一个数组,装的是中间件的方法,子Group会继承父的中间件
basePath 定义的Group的主路径
engine 核心引擎的指针。需要注意,基于主Group创造出来的子Group们不仅会使用主中间件还会共用一个主引擎
root 是否为根Group,只有我们New出来的主引擎自带的Group这里才会是true
注意,整个RouterGroup只负责绑定路由树,不负责匹配
RouterGroup
method 方法类型:GET,POST等
root 方法类型对应的具体路由树
这个结构就是主引擎中用来存储路由树的结构
methodTree
路由树的节点信息
path 节点路径,比如上面的blog,a,bout等等
fullPath 完整路径
indices 字母索引,对应的就是上边的a,下面的about和article的b和r 也就意味着,这个分支下面还有至少两个分支
priority 优先级,当前节点的子节点越多,这个值会越大
children 当前节点的所有子节点
static: 静态节点(默认)
root: 根节点
catchAll: 带有通配符的节点,也就是*
param: 参数节点
nType 节点类型
handlers 函数链
node
核心结构
addRoute 这个无法并发安全。言外之意就是,这个前缀树结构不是并发安全的。
addRoute() 添加一个路径
getValue() 匹配一个路径
核心方法
Map(go 自带的HTTP)
正则匹配(gorilla/mux)
其他方法
Router
通过将横切关注点从主要业务逻辑中分离出来,然后以模块化的方式进行管理和重用
也是编程范式的一种
绝大多数的现代框架的中间件模块都是基于AOP的思想来设计的
核心思路:AOP
也叫链式函数,将多个Func按照一定的顺序组合起来
索引
函数注入
函数链实现洋葱模型有两个思路
函数链
一种软件架构模式,旨在实现松耦合、可维护和可测试的应用程序
核心思想是将应用程序分为多个层次,每个层次具有不同的职责和依赖关系。这些层次按照一定的规则进行组织,以便实现解耦和可测试性。
外部层(Outermost Layer)
应用服务层(Application Services Layer)
领域层(Domain Layer)
基础设施层(Infrastructure Layer)
层级
解耦性
可测试性
可维护性
特点
他也是领域驱动模型(DDD)的一种实践
洋葱模型
实现思路:通过函数链的方式实现洋葱模型
type HandlersChain []HandlerFunc
type HandlerFunc func(*Context)
参考路由器
Use()
Group()
combineHandlers()
Func
Next 函数链操作的核心,也是洋葱模式的一种实现方式
Next()
Abort 用来将函数链的索引设置为最大值,会终止函数链的执行
Abort()
流程
用来打印请求日志,包括起始时间,耗时,URL,参数,CODE 码等等
Log
大多数的框架都会有一个最外层的recover中间件,以确保出现panic时,服务还能正常使用。
Recover
自带的中间件
Middleware
获取一个根节点。相当于拿到了Context的Root节点。注意在代码中不要随便使用。
context.Background()
获取一个空节点。理论上可以把他当做根节点,请不要这样搞。这个方法只会用在需要传一个CTX,但实际不产生任何用处时,充当占位符。
context.TODO()
空的Context
常用的一种方法,返回一个可以取消的上下文。当父辈执行取消操作时,会将信号同步给他的子孙们,他们同时也会响应取消当前的操作。
context.WithCancel()
最常使用的一个方法。带有一个超时机制的上下文。可以手动触发取消也可以在超时之后自动触发取消。
context.WithTimeout()
不常用的一个方法。 带有一个时间点的上下文。可以手动触发取消也可以在到了时间点之后自动触发取消。
context.WithDeadline()
最不常用的方法,通常情况下,我们是不会在上下文里穿一些数据的。最常见的只有传Trace和Token
context.WithValue()
其他Context
官方Context的原理
用来重置或者复制一个Context
将现有Context的绝大多数字段全部重置为初始值
reset()
拷贝一个当前的Context,提供给其他协程使用
handlers,skippedNodes,errors等不会被复制,在使用时需要注意
Index会被直接设置为abort的值,也就意味着,这个Context实际上是没有办法向下继续执行的。
Copy()
CONTEXT CREATION
控制流,我们常用的Next和Abort就在这一模块
通过Index来确定当前需要执行的handler,这里会和中间件联动
直接将Index设置到abort的状态,后续方法也不会再执行了
FLOW CONTROL
错误管理
该方法会把err信息装到Context的Errors切片中,非常适合中间件使用
使用方最终可以将Errors的错误信息全部写进日志中
注意他返回的Error是gin框架中自定义的错误
Error()
ERROR MANAGEMENT
元数据管理,就是Key中存储的数据,gin帮我做了一套数据转化的方法,直接获取我们需要的字段类型
Set() 向一个带锁的MAP中写入一个值的经典写法 ,值得学习
从Pool中获取一个新的Context时
需要重置当前Context时
该方法被用在两个地方
Get()
MustGet() 唯一特殊的方法。查找的键值不存在,直接Panic。
其他 一套获取指定类型的方法,核心就是反射,没啥技巧
注意,我们仍然可以调用delete()方法删掉一个元数据,因为他的底层是个MAP
METADATA MANAGEMENT
获取用户输入的数据,看着一大堆实际上关键函数就几个我们后续会展开
Param() 获取动态参数的方法。
GetQueryArray() 获取URL参数的核心方法,其他方法都是基于此方法。
GetPostFormArray() 获取Form表单的核心方法,其他方法都是基于此方法。
get() 获取MAP类型返回值的核心方法,不常用。
ShouldBindWith() 绝大多数bind方法的核心。后续我们专门展开讲一讲。
INPUT DATA
返回内容,主要是设置response的header和body
Header() 用来设置一些头部信息。
SetCookie() 底层是http.SetCookie的封装。
File() 返回一个文件,实现下载功能时会用到。
Stream() gin 理论上确实可以返回一个数据流,只是用的很少。
RESPONSE RENDERING
用来和客户端协商请求的响应格式的。有些时候客户端会带上需要的返回内容,XML或者Json。
Negotiate() 根据客户端的需求,返回恰当的类型。非常智能,但用的很少。
CONTENT NEGOTIATION
对官方Context接口的具体实现,我们可以细细品一品。
GOLANG.ORG/X/NET/CONTEXT
Gin Context
Context
Bind
Render
Bind&Render
参数校验
Request
Other
Gin框架源码
gin
echo
Web框架
go-zero
go-mico
kratos
微服务框架
优点:提高开发效率
编排SQL需要消耗性能
会降低开发人员对SQL的敏感度
出问题时不好排查
缺点
因此,要学会用,但不推荐用
Gorm
Viper
Zap.Log
Cobra
Colly
Swagger
其他常用包
框架
算法
数据结构
算法与数据结构
SQL注入
XSS攻击
DDOS攻击
CC攻击
常见的攻击方式
编程安全
git
linux
docker
Apifox
常用工具包
连接层
优化层
解析层
引擎层
MySQL 的服务架构
与其他引擎的区别
还有哪些引擎
事务
日志
锁
innodb
主备同步
集群与代理
MySQL
Redis
kafka
mongoDB
elasticsearch
oss
常用组件
云原生
基础架构
设计模式
分布式
微服务
架构知识
计算机组成原理
计算机网络
软件工程
操作系统
数据库
基础知识
注册与登录
分页问题
超卖问题
大流量问题
读写一致性问题
其他问题
常见业务场景
自测
联调
压测
全链路测试
测试
监控
测试与监控
GO初级知识地图
0 条评论
回复 删除
下一页