golang
已收录文章:1090篇
-
sync.Once通过确保初始化函数只执行一次来实现线程安全的单例。1.使用包级变量保存单例实例;2.通过GetInstance方法调用once.Do进行初始化;3.初始化逻辑仅在首次调用时执行,后续调用直接返回已有实例。应用场景包括配置管理、日志记录器、数据库连接池和缓存服务。注意事项:Do方法仅接受无参函数,避免长时间阻塞,不可复用Once对象,多个初始化步骤需合并到一个函数中。261 收藏
-
在Go语言中,错误处理应优先使用标准库的errors包和自定义错误类型。1.使用errors.New定义静态错误值,避免字符串拼接以确保可比较性;2.调用errors.Is判断特定错误,而非通过字符串比较;3.需要添加上下文信息时,使用fmt.Errorf的%w格式包装错误,以便保留错误链并能被Unwrap解析;4.自定义错误类型实现error接口,可携带结构化信息便于分类和展示;5.实际开发中建议统一错误结构、避免过度包装、谨慎使用哨兵错误,并在日志中记录上下文信息,同时在单元测试中验证错误行为。261 收藏
-
Golang的strings库提供了丰富的字符串处理函数,能高效进行查找、分割、连接、替换、大小写转换及去除空格等操作。1.查找子字符串可用strings.Contains、strings.Index和strings.LastIndex,复杂模式匹配则使用regexp包;2.分割与连接字符串可使用strings.Split、strings.SplitN和strings.Join;3.替换字符串可使用strings.Replace、strings.ReplaceAll或regexp.ReplaceAllSt260 收藏
-
在Golang中设计长连接心跳机制应结合deadline与keepalive。一、心跳机制用于检测连接存活,客户端或服务端定期发送心跳包,连续未响应则断开重连;二、Go的deadline控制读写超时,如SetReadDeadline设置读操作截止时间,超时返回timeout错误;三、TCPKeepalive是系统级探针机制,启用需调用SetKeepAlive(true)与SetKeepAlivePeriod设置探针间隔;四、推荐组合使用:应用层心跳快速响应,传输层keepalive作为兜底保障,建议参数关260 收藏
-
Golang的expvar库可用于暴露程序运行时指标并支持自定义监控。1.默认指标通过/debug/vars路径提供,如内存使用、goroutine数量等,需启动HTTPserver访问;2.可通过expvar.NewInt或expvar.NewString添加自定义计数器或字符串变量;3.指标可通过中间件转换为Prometheus格式,如使用expvarmon或prometheus/client_golang中的expvar_collector;4.注意路径冲突、版本差异及频繁操作性能影响等问题。259 收藏
-
OpenTelemetry(OTel)是微服务链路追踪的主流解决方案,它提供了一套标准的可观测性工具,用于采集分布式系统中的Trace、Metric和Log。其核心概念Span代表一次操作的执行时间段,通过SDK可便捷集成到Go语言编写的微服务中。接入步骤包括安装依赖包、初始化TracerProvider并设置采样策略、配置Exporter导出Span数据、以及在服务中注入中间件或手动添加Span。以chi路由库为例,通过引入otelhttp中间件可以自动为每个HTTP请求创建Span,并通过gRPC协议259 收藏