golang
已收录文章:86篇
-
Go中实现任务超时取消需用context.WithTimeout创建子上下文并defer调用cancel,监听ctx.Done()及时退出;context取消链为单向父子继承,子取消不影响父;I/O操作须用原生支持Context的方法或手动检查Done()。411 收藏
-
Golang函数参数始终为值传递,传递值类型时复制整个数据,函数内修改不影响原始变量;若需修改,则应传递指针。410 收藏
-
gotest支持多种参数以提升测试效率。使用-v可查看详细输出;-run配合正则表达式运行指定测试函数,如gotest-runLogin;-timeout设置超时时间,默认10分钟,例如gotest-timeout30s;-parallel控制并行测试的最大数量,需在代码中调用t.Parallel();-bench运行基准测试,如gotest-bench=.,可结合-cpu指定核心数;通过-coverprofile生成覆盖率报告,并用gotoolcover-html查看HTML报告。参数可组合使用,如同时390 收藏
-
合理利用并发、控制资源消耗可提升Gopipeline性能。通过goroutine与channel实现并行处理,CPU密集型任务以GOMAXPROCS为基准控制并发数,IO密集型可增加并发度;使用带缓冲channel减少阻塞,避免无限制创建goroutine;确保关闭channel防止泄漏,结合context与select实现取消和超时;用sync.Pool复用对象减少GC压力,传递指针降低拷贝开销;通过semaphore限流、context控制超时,并采集指标监控系统负载,保持稳定性。389 收藏
-
首先,将Golang微服务部署到Kubernetes需通过容器化应用并利用Kubernetes编排能力实现自动化管理。具体包括:编写Dockerfile进行多阶段构建,生成轻量、安全的镜像;将镜像推送到注册中心;使用Deployment定义Pod副本、资源限制及健康探针,确保高可用;通过Service提供稳定网络端点,支持内部或外部访问。结合CI/CD可实现全流程自动化,提升部署效率与系统韧性。1.构建阶段使用golang:1.22-alpine编译应用,禁用CGO生成静态二进制;2.运行阶段基于alpi370 收藏
-
使用带缓冲的channel可限制Goroutine数量,通过容量为N的struct{}类型channel作为信号量,每启动一个goroutine写入值,结束时读出,确保最多N个并发执行。366 收藏