golang
已收录文章:14145篇
-
Go通过调用DockerAPI、使用OCI库或集成CI/CD工具实现镜像版本管理,常见做法是在构建时动态生成标签;可通过git命令获取版本信息,结合-ldflags注入编译变量,并在Makefile中调用dockerbuild;使用github.com/docker/docker/client可编程打标签并推送镜像;更普遍的是在CI流程中根据分支和tag决定镜像标签,实现自动化发布。189 收藏
-
接口方法应仅在可能失败时返回error,如I/O、网络操作;简单操作可省略。需定义清晰的自定义错误类型,如ErrUserNotFound,供调用方通过errors.Is判断。涉及阻塞的操作应接收context.Context并在取消或超时时返回ctx.Err()。实现不得隐藏错误或主动panic,错误应统一返回,确保调用方能可靠处理。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 收藏
-
前言 我们通常用 Golang 来开发并构建高并发场景下的服务,但是由于 Golang 内建的GC机制多少会影响服务的性能,因此,为了减少频繁GC,Golang提供了对象重用的机制,也就是使用sync.Pool构建对188 收藏