草庐IT

并行执行

全部标签

go - 迭代结构并执行数据库查询

所以我是go新手,我有javascript/node背景,为了练习,我一直在将我的一些javascript代码重写到go中。我有一个结构(在节点中它是我的对象),我需要迭代它并执行两个数据库查询。我有一些有用的东西,但它似乎很昂贵且重复。结构:typeSiteUsersstruct{Activestruct{Moderators[]string`json:"moderators"`Admins[]string`json:"admins"`Regulars[]string`json:"regulars"`}`json:"active"`}然后在我处理返回绑定(bind)到此结构的JSON

go - Chromedp 不在 ActionFunc 的循环内执行操作

我有一个包含术语列表的slice,我想在某个搜索引擎页面中搜索每个术语,所以我这样做:funcrisk(slice[]string)chromedp.Tasks{returnchromedp.Tasks{chromedp.Navigate("https://testpage"),chromedp.WaitVisible("#query_box",chromedp.ByID),chromedp.ActionFunc(func(context.Context,cdp.Executor)error{for_,element:=rangeslice[2:]{fmt.Println(elemen

sql - 是否可以在执行查询时传入参数数组而不是单独传递每个参数?

有谁知道在执行查询时是否可以传递参数数组而不是单独传递每个参数?所以不是:query=“select*fromgridwheretest1=?ANDtest2=?”g.DB.Query(query,params[0],params[1])类似于:query=“select*fromgridwheretest1=?ANDtest2=?”g.DB.Query(query,params)我试过像这样打开slice:g.DB.Query(query,params...)但是报错:cannotuseparameters(type[]string)astype[]interface{}inargu

for-loop - 暂停for循环的执行

我有一个API,我也在发布一个小的JSON对象。这作为一个无限循环运行,循环7种颜色(彩虹)并将它们发送到上述JSON对象中。我正在连接的API的速率限制为每分钟40个请求。我不想达到速率限制,所以我设计了一种方法来避免这种情况;我有一个全局变量,用于存储允许我发出的请求数我有一个函数,它保存一个代码集,每60秒运行一次,并填充存储我的请求的全局变量然后我有一个永无止境的for循环,它运行并检查仍然允许发出的请求数,如果它大于0,那么我们发出下一个请求,如果不是,那么我们就休眠一秒钟再试一次看起来有点像这样:varrateLimitintfuncmain(){request:=gore

postgresql - 事务执行后停留在pg_stat_activity状态

我对PostgreSQL和golang都很陌生。主要是,我试图了解以下内容:为什么我需要Commit语句来关闭连接和另外两个Close电话没用?也非常感谢有关我使用游标的正确/错误方式的指示。在下面的函数中,我使用了gorp要创建一个CURSOR,请逐行查询我的Postgres数据库并将每一行写入编写器函数:func(txn*gorp.Transaction,qstring,params[]interface{},myWriterfunc([]byte,error)){cursor:="DECLAREGRABDATANOSCROLLCURSORFOR"+q_,err:=txn.Exec

go - 哈希字符串的有限并行性

这个问题在这里已经有了答案:Howwouldyoudefineapoolofgoroutinestobeexecutedatonce?(5个答案)关闭4年前。尝试解决从文件中读取电话号码(逐行)并同时对它们进行哈希处理(md5)的问题,最多100个并发进程,创建固定数量的goroutine。尝试使用gopipeline和boundedparallelism但没有用。有什么指导吗?这是我试过的,https://play.golang.org/p/vp7s512l8w4

http - go 程序在执行数小时后系统地因 semacquire 问题崩溃

这是我的代码的摘录:funcsendTo(urlstring,someDataPoints[]DataPoint){ro:=&grequests.RequestOptions{JSON:someDataPoints,InsecureSkipVerify:false}grequests.Post(url,ro)return}funcforward(someDataPoints[]DataPoint)int{endpoint:="https://example.org"gosendTo(endpoint,someDataPoints)}forward函数每秒被调用大约100次。该程序运行了

go - 当我在 Windows 10 中执行使用键盘控制 dji tello 无人机的 go 文件时发生错误

我有一个名为drone_control.go的go文件,它通过点击键盘按钮来控制djitello无人机。当我尝试使用命令提示符执行此文件时,它显示错误*exec:"stty":executablefilenotfoundin%PATH%我正在使用windows10和gobot框架来控制无人机。以下是我的drone_control.go文件的内容。packagemainimport("time""gobot.io/x/gobot""gobot.io/x/gobot/platforms/dji/tello""gobot.io/x/gobot/platforms/keyboard")func

c# - 来自 golang 和 c# 的 elixir 函数的并行或异步任务

我正在和Phoenix一起学习Elixir。我很容易地构建了一些RESTAPI服务器,但是我还需要实现一个要求。我需要能够执行并行或异步任务以从后端调用/执行某些API,并将这些结果放入JSON响应中。这就是我从Go和C#中大致实现它的方式//GolanguserCount:=make(chanint)usersList:=make(chan[]Users)gogetAggregateUserCounts(userCount)gogetGetUsersList(usersList)//dootherheavytasksfromherehttpJsonResponse(map[strin

go - 如何运行多步 cron 作业,但仍然能够手动执行单个步骤?

我在Go中有一个包含步骤A、B和C的数据管道。目前这些是三个二进制文件。他们共享同一个数据库,但写入不同的表。在本地开发时,我一直在运行./a&&./b&&./c。我希望将此管道部署到我们的Kubernetes集群。我希望A->B->C每天运行一次,但有时(为了调试等)我可能只想单独手动运行A或B或C。是否有一种在Kubernetes中实现此目的的简单方法?我没有找到很多这方面的资源,所以这可能表明我的应用程序设计存在问题? 最佳答案 创建一个包含所有三个二进制文件的docker镜像和一个运行所有三个二进制文件的包装器脚本。然后部署