草庐IT

线程执行

全部标签

SQLBoiler ORM,如何在没有绑定(bind)的情况下执行原始查询?

我在这里试用这个ORM生成器https://github.com/vattle/sqlboiler我正在尝试使用boil.SQL执行原始查询,我可以在他们的文档中看到这一点。但是当我执行boil.SQL().时,我发现唯一可用的方法是绑定(bind)。有没有一种方法可以在不绑定(bind)到对象的情况下执行查询?因为我不需要返回任何结果。谢谢。 最佳答案 boil.SQL()返回一个*boil.Query。如果您不关心结果,可以将其传递给boil.ExecQuery()。q:=boil.SQL("executefoo()")_,er

multithreading - Golang 线程池调度程序的目的和顺序

我刚刚用go写完了一个简单的代理应用程序:代码从一个接口(interface)获取UDP数据包,加密数据,然后使用TCP将其发送到另一个接口(interface)。目前,我正在使用三个goroutines:一个用于接收数据,一个用于加密,一个用于发送数据。我刚刚开始尝试寻找提高代码效率和速度的方法。首先,我想为每个需要加密的数据包创建一个新的goroutine,但在阅读了以下两篇博文后,我明白这不是正确的做法:http://marcio.io/2015/07/handling-1-million-requests-per-minute-with-golang/http://nesv.g

go - Go文本/模板中niladic函数"Catch"错误继续执行

如果我有一个具有如下函数的结构:typedatastruct{}func(d*data)Foo()(string,error){return"",errors.New("bad")}然后我在模板中调用.Foo,如下所示:{{.Foo}}我得到一个错误:errorcallingFoo:bad这与text/template的文档一致:Thenameofaniladicmethodofthedata,precededbyaperiod,suchas.MethodTheresultisthevalueofinvokingthemethodwithdotasthereceiver,dot.Met

elasticsearch - Golang : Using ElasticSearch library called Goes, 如何为 bool should 方法编写可执行代码?

我正在使用gos库(https://github.com/OwnLocal/goes),它是Golang中ElasticSearch的包装器。在ElasticSearch查询中,我们可以这样运行:{"query":{"match":{"user_id_1":"438018"}}}而且有效。对于使用gos的golang,你可以像这样运行它:varquery=map[string]interface{}{"query":map[string]interface{}{"match":map[string]interface{}{"user_id_1":"438018",},},}这是我的问题

http - 多线程Go for HTTP get

我在一个API中使用Go来获取我所在城市的公交车频率,但是当我尝试使HTTPGet访问许多URL时,我有点卡在了线程上。如果没有并发,程序需要超过16分钟才能完成1500个url调用以获取HTTP状态代码,我试图使用并发,但在阅读了很多帖子后我不明白goroutines是如何工作的......想法是制作一个函数并更改请求的数量,如下所示:gogetBusPostStatus(600,800)但我完全坚持...代码如下:packagemainimport("fmt""net/http""strconv""time")variint=0varconvStrstringvarmessage=

linux - 启动由 Go 编译器构建的可执行文件时出错

我是Go的新手,我的MAC上有一个用Go编写的docker插件。我使用以下命令构建它:envGOOS=linuxGOARCH=amd64gobuild输出是二进制文件。当我将它复制到CoreOS并尝试执行时:./my-binary-file结果是:"2016/12/0708:05:00ErrorGrouprootnotfound"执行文件的操作系统是CoreOS。我检查了MAC和CoreOS,它们都是x86_64。为什么我会收到这个错误?编辑:问题出在ServerUnixGroup中。它应该是“docker”而不是“root”。 最佳答案

go - 在 golang 中执行进程内动态插件的一种方法

最近我想在golang中构建一个动态插件框架,我知道plugin构建模式还没有实现。所以我正在考虑将go插件构建到c风格的共享对象中,并且主程序使用C.dlopen加载插件。复杂的数据结构可以通过json编码的字符串传递。这个方法可行吗?或者是否会造成任何可预见的不利因素?提前致谢。 最佳答案 此方法不是执行动态插件加载/重新加载的可行方法。详情在这里:https://github.com/golang/go/issues/11100连golang1.8的plugin特性都不支持reload了。

go - 在 "go-getable"包中选择不同的可执行文件名称

是否可以有一个“go-getable”的cli-package(packagemain),但二进制文件安装在不同的名称下?例如拥有一个仓库github.com/exaring/foo-cli但是gogetgithub.com/foo/foo-cli会安装一个名为foo的二进制文件(不是foo-cli)?重点是要有一个富有表现力的存储库名称,但要有一个简短且易于键入的可执行文件。 最佳答案 如果您同意用户运行gobuild而不是goget,您可以这样做:gobuild-ofoogithub.com/foo/foo-cli否则,您可以将

go - 如果您希望代码停止执行,是否必须在 http.Redirect 之后返回?

如果我在中间件中使用http.Redirect,我是否必须在调用next.ServeHTTP(w,r)之前明确地在http.Redirect之后返回?如果我有这样的事情,我是否必须在每个http.Redirect之后显式返回以使代码在重定向后停止执行?如果我不回来会怎样?//HTTPSNonWWWRedirectredirectshttprequeststohttpsnonwww.funcHTTPSNonWWWRedirect(nexthttp.Handler)http.Handler{returnhttp.HandlerFunc(func(whttp.ResponseWriter,r

sql - 如何使用Golang直接从文件执行mssql脚本

我一直在寻找上述问题的答案,但没有成功。对不起,如果它是重复的。所以基本上我试图直接从文件中执行一个sql脚本,但我一直收到“''附近的语法不正确。”错误funcAnotherDatabase()(sql.Result,error){rc,err:=os.Open("./myscript.sql")iferr!=nil{returnnil,err}buf:=new(bytes.Buffer)buf.ReadFrom(rc)contents:=buf.String()db,err:=sql.Open("mssql","mydatabase")iferr!=nil{returnnil,er