golang
已收录文章:13927篇
-
基于Golang构建FaaS平台并扩展Knative,需理解其Serving、Eventing和Brokering三大组件;Serving为核心,负责函数部署与自动扩缩容,用户函数以HTTP服务形式实现,通过Docker打包为镜像由Knative管理;可使用Golang开发自定义Controller、EventSourceAdapter或Autoscaler实现深度定制;推荐ko、Kind/Minikube、kubectl与kn工具链进行高效部署与调试,最终实现灵活可扩展的云原生FaaS系统。189 收藏
-
panic用于处理Go中严重异常,recover必须在defer中调用才能捕获panic并恢复流程;2.关键业务逻辑可通过defer+recover设置安全屏障,防止程序崩溃;3.子goroutine需独立设置recover,否则panic会导致整个程序终止;4.可封装通用WithRecovery函数减少重复代码,提升可维护性。核心是合理使用panic+recover机制,在关键路径兜底但不替代常规错误处理。189 收藏
-
首先实现指标采集与健康检查,再集成Prometheus暴露HTTP请求计数和耗时,通过/healthz接口检测服务状态,结合定时器触发阈值告警,并使用zap记录结构化日志以联动监控分析。189 收藏
-
背景 在实现图片转码的需求时,需要支持最大 500 个图片下载后转换格式; 如果是一个一个下载后转码,耗时太长,需要使用 goroutine 实现 500 个图片并发下载后,并发转码; 但自测过程中发现188 收藏
-
之前整理过结构体和json转换的文章:GoFrame必知必会之Scan:类型转换,今天整理同样比较重要的ORM相关的文章。 gf是支持ORM原生操作的,在ORM链式操作执行不了太过于复杂的SQL操作时,可以交188 收藏
-
性能监控 一、web项目(如gin中) 1.使用ginpprof import "github.com/DeanThompson/ginpprof" router := gin.Default() ginpprof.Wrap(router) 2.使用pprof 只需要在main.go中引入:_ “net/http/pprof” 访问:127.0.0.1:8080/debug188 收藏