golang
已收录文章:653篇
-
Golang微服务容器监控需构建四维可观测体系:1.用prometheus/client_golang暴露Metrics,供Prometheus抓取;2.日志输出至stdout,采用zap等结构化库,配合Fluentd收集;3.集成OpenTelemetry实现分布式追踪,导出至Jaeger;4.提供/healthz和/readyz探针,支持Kubernetes健康检查。241 收藏
-
使用中间件生成并传递TraceID,结合日志输出与跨服务传递,实现请求追踪;可通过OpenTelemetry构建标准化分布式追踪体系。240 收藏
-
Golang微服务容错需多层协同,通过熔断器防止级联失败,设置超时与指数退避重试提升调用成功率,使用rate包限流保护系统,结合优雅降级返回默认或缓存数据,保障高可用。240 收藏
-
使用gobreaker实现熔断,通过Closed、Open、Half-Open状态防止雪崩;结合rate.Limiter令牌桶限流控制流量洪峰;二者封装为中间件提升复用性,增强系统稳定性。239 收藏
-
使用bufio.Scanner可高效逐行读取文件。先用os.Open打开文件并创建Scanner,通过forscanner.Scan()循环读取每行内容,scanner.Text()获取字符串,结束后检查scanner.Err()确保无I/O错误;若处理超长行,需调用scanner.Buffer设置更大缓冲区,如1MB,以避免报错。该方法适合大文件或按行解析场景。239 收藏
-
Go语言从1.11起使用gomod管理依赖,取代GOPATH;通过gomodinit创建模块,自动生成go.mod文件;导入外部包如gorilla/mux后执行gobuild会自动下载依赖并更新go.mod和go.sum;常用命令包括gomodtidy清理依赖、goget升级版本、golist查看依赖、gomoddownload下载缓存;replace指令可替换依赖路径,但仅限本地调试,不宜提交至生产环境。238 收藏