草庐IT

付诸实践

全部标签

inheritance - 处理 Go 中缺乏继承的最佳实践

我正要开始编写一个新的应用程序,我正在考虑用Go编程,但我没有这方面的经验。由于Go不支持继承,我如何忠实地将这样的域翻译成Go,同时仍然符合Go的哲学?:一个人有2条腿和2条胳膊,可以走路。音乐家是一个人,有乐器并且可以演奏,有分区并且可以阅读。但没有人只能是音乐家,因为音乐家拥有并会演奏特定的乐器。fiddle手是拥有fiddle并会拉fiddle的音乐家钢琴家是拥有钢琴并会弹奏钢琴的音乐家。当一个fiddle手/钢琴家走在街上时,每个人都只把他看作一个人。也许我们可以像这样重新构造域以删除任何"is"关系,以便它可以翻译成Go:fiddle手有一个人的部分,一个音乐家的部分,一把

json - Kafka - Json(最佳实践)

我需要将RESTAPI调用的输出推送到KAFKA。Restapi返回json输出,其中包含支持信息以及数据输出到json.RawMessagetypeResponsestruct{RequestIDstring`json:"requestId"`Successbool`json:"success"`NextPageTokenstring`json:"nextPageToken,omitempty"`MoreResultbool`json:"moreResult,omitempty"`Errors[]struct{Codestring`json:"code"`Messagestring`

go - 确保 goroutine 清理,最佳实践

关于如何确保生成的goroutine在长时间运行的进程的上下文中正确“关闭”,我有一个基本的理解问题。我观看了有关该主题的讨论并阅读了有关最佳实践的内容。为了理解我的问题,请参阅视频“高级Go并发模式”here对于以下内容,如果您在您的机器上运行代码,请导出环境变量GOTRACEBACK=all以便您能够在panic后看到例程状态。我将原始示例的代码放在这里:naive(它不会在goplayground上执行,我猜是因为使用了时间语句。请复制代码并在本地执行)naive执行后panic的结果是panic:给我看堆栈协程1[正在运行]:panic(0x48a680,0xc4201d848

web-services - 使用 gin-gonic 编写 Web 服务的最佳实践是什么

在其他框架(如RubyonRails)中,它们具有目录结构,例如在何处保存模型相关代码、在何处保存View相关代码、在何处保存Controller相关代码以及在何处播种数据库。gin-gonic有没有目录组织?或者有什么建议吗? 最佳答案 Gin不是一个自以为是的框架。这是我为REST服务遵循的目录结构契约(Contract)包含请求者与服务之间的契约(Contract)每个资源的请求结构每个资源的响应结构错误响应结构核心此目录包含执行实际工作的代码不管请求最初是httpHTTP服务路线http处理程序处理http请求等的代码这种方

go - 对 golang 项目布局 repo 在实践中的工作方式感到困惑

本题引用热门project-layout.这只是一种布局代码的方式,但二进制文件的实际编译将在/cmd/app1//cmd/app2/所以如果我有一个网站,它仍然会被认为是一个cmd应用程序,它只会启动http监听器等。或者整个布局中是否有多个“入口”点,而不仅仅是在cmd文件夹中?您将如何使用此布局实际构建和运行您的应用程序?(或者其中之一,因为据我所知它支持多个)是不是这样:去构建cmd/app1/*.go? 最佳答案 你可以gobuild./cmd/app/例如我有这个模块├──cmd│  ├──cli│  │  └──mai

html - 嵌入数据或不嵌入数据什么是服务/解析动态内容的最佳实践

我开始使用go用于提供动态html内容、解析模板、替换变量等。到目前为止一切都很好,我发现我可以创建一个二进制文件并通过使用像go-bindata这样的包来部署一个包含所有静态文件的文件。.但是当谈到性能时,应遵循哪些最佳实践?如果我是对的,拥有一个嵌入所有静态内容的二进制文件将导致文件更大。拥有一个需要/依赖于仅在启动时解析模板(*.tpl)的二进制文件,其大小可能较小,但需要与所有静态内容一起提供。如果空间是唯一的区别,在某些情况下使用单个二进制文件看起来更舒服,但我不是该主题的专家,我想知道一些最佳实践以遵循并关注性能. 最佳答案

database - 在 go http 中的自定义处理程序中传递 *gorm.db 实例的最佳实践

我正在创建一个自定义网络处理程序来处理网络应用程序中的路由。处理程序是typeCustomHandlerstruct{Db*gorm.DB}然后是接收函数:func(hCustomHandler)Index()http.Handler{returnhttp.handlerFunc(whttp.ResponseWriter,r*http.Request){//Somecode//useh.Db.Find(),etc.})我将其传递给我的路由器作为//InpackagecustomHandler:=&CustomHandler{*gormInstance}//I'vealreadygott

firebase - 在 Firestore 中忽略 Nil 值的最佳实践

我正在使用Golang(用于API定义的Go-Swagger)和Firestore作为我的文档存储来构建自定义网络服务。一切正常,除了在更新数据库时变得“尴尬”。我有一个解决方案,但我不相信它是最优雅的。有没有其他人遇到过这个,他们是如何解决的....问题陈述:当我写入数据库时​​,Nil值正在覆盖firebase中的现有值建议的解决方案-我的API在可选参数上有json:"omitempty"并且将传入nil值(而不是获取默认的golang值)。我计划将Struct传递到API中,并一次将一个attr填充到firestore正在使用的我的Struct中。我有性能问题,但不想将我的AP

go - 未导出的结构最佳实践? (戈林特提示)

我有以下包:packagemypkgtype(//mystruct...mystructstruct{Sstring})//New..funcNew()*mystruct{return&mystruct{S:"test"}}我是这样使用的:packagemainimport("fmt""test/mypkg")funcmain(){x:=mypkg.New()fmt.Println(x.S)//thisfailsintendedy:=mypkg.mystruct{S:"andre"}fmt.Println(y.S)}为什么golint提示我未导出的结构?我的意图是防止在构造函数调用之外

go - golang中处理websocket通信的设计实践

我是新手,正在尝试通过更换nodejs服务器来学习它。我的nodejs服务器具有以下组件:它收到来自客户端的websocket消息。客户端将为消息提供唯一ID和key。服务器将根据key处理消息(很像REST接口(interface)),并使用唯一ID将消息返回给客户端,以便客户端知道服务器正在响应的消息。对于某些消息,服务器会生成一个外部进程(每个连接一个)。然后,服务器将充当生成进程的“客户端”,发送具有唯一ID的JSON消息并接收回数据。此实例中的服务器充当派生进程和客户端之间的中介。在node上让它正常工作是微不足道的。我只是将生成的进程添加到我的“主”中的连接并在主中使用了回