-
本地启动多个微服务时端口冲突应避免硬编码,改用环境变量(如PORT)或自动探测可用端口(开发环境);服务间调用需统一网络地址(如host.docker.internal或127.0.0.1)并设置合理超时;推荐使用air热重载、OpenTelemetry接入Jaeger实现链路追踪,关键注意环境变量、端口、context透传。
-
测试文件读写时不能直接操作真实磁盘,因存在残留、并发冲突、权限等问题;应使用os.CreateTemp+deferos.Remove或fstest.MapFS进行隔离。
-
WaitGroup用于等待多个goroutine完成,通过Add增加计数、Done减少计数、Wait阻塞直到计数为零,确保主协程在所有子任务结束后再继续执行。
-
Go中数组赋值是值拷贝(类似深拷贝),切片赋值是头信息拷贝(浅拷贝),底层数组共享;深拷贝切片需make+copy或append(nil,s...);嵌套指针或切片需递归处理。
-
Go语言通过import关键字和模块系统管理依赖,标准库包如fmt、os可直接导入使用;项目初始化后,导入第三方包如github.com/sirupsen/logrus会自动下载并记录到go.mod和go.sum中;支持基础、别名和匿名导入方式;建议将import分为标准库、内部包、第三方包三组,避免点操作符,定期执行gomodtidy清理冗余依赖,确保项目结构清晰与依赖一致性。
-
指针接收者用于修改结构体或提升大对象性能,值接收者适用于小型只读操作。Go自动处理调用转换,建议大结构体或需修改时用指针接收者,保持方法一致性,并注意并发安全。
-
defer在Go中用于延迟执行函数,确保资源释放;多个defer按LIFO顺序执行;参数在defer语句执行时即求值,而非调用时。
-
责任链模式通过将处理器串联实现请求的链式处理,Go中以接口与结构体组合构建日志、权限、校验等中间件流程,解耦发送者与接收者,提升灵活性,适用于多对象处理同一请求且需动态指定处理顺序的场景。
-
统一定义RPC错误类型,使用结构化错误码与消息,结合重试机制、上下文超时控制及链路追踪,提升微服务稳定性与可维护性。
-
在Go中通过代码注释+swag工具链自动生成RESTful接口文档,注释以//@开头置于handler上,定义元信息;需导出结构体并用json/swaggertype标签控制Schema;执行swaginit生成docs,集成SwaggerUI即可访问。
-
context能控制HTTP请求生命周期是因为http.Client通过net.Conn的可取消读写机制,在连接建立、TLS握手、请求发送、响应读取等各阶段监听context.Done(),一旦触发即关闭连接并返回对应错误;必须用http.NewRequestWithContext()构造请求并配合client.Do()使用,快捷方法如client.Get会忽略传入context。
-
Go中无需Facade类即可实现外观模式,因其通过包封装、导出简洁函数(如ProcessPayment)协调子系统调用,隔离复杂性;关键在接口统一、错误语义清晰、依赖可控。
-
推荐用多阶段构建:第一阶段用golang:alpine编译(需CGO_ENABLED=0和-ldflags="-s-w"),第二阶段用scratch或alpine:latest运行二进制;避免直接用golang:alpine运行,因其体积大、攻击面宽、启动慢。
-
Go语言标准库net/url可解析URL结构并提取查询参数,支持多值同名参数处理、HTTP请求中直接获取、安全校验及敏感参数规避。
-
Go的测试文件(_test.go)默认不参与构建,因此无法直接导出供其他包的测试文件使用;但可通过构建标签(buildconstraints)将共享测试数据定义在非_test.go文件中,并配合-tags参数启用。