jjzjj

goroutine

全部标签

go - 获取 "parent"goroutine 的堆栈以及 "child"的堆栈

是否有一种方法,可能打开了一些调试标志,以获取所有goroutine的堆栈跟踪转储以及“父”goroutine的堆栈跟踪(此处使用“parent”表示goroutine执行了对gofoo()的调用,启动了相关的goroutine)。这个问题的背景是我有一个连接泄漏并注意到awaitDone(在sql包中)有很多goroutines被阻塞,并且这些goroutines是在创建连接的地方产生的。 最佳答案 runtime.Stack()将为您提供运行时知道的所有堆栈信息。阅读输出可以看到,对于Goroutines,它们被设计为不包含其祖

multithreading - goroutine 多次使用同一行

目前我有一个场景,我有一个巨大的文件(例如我要说500k行的文本),我的想法是使用worker(线程)来处理它们,每个线程100个。运行我的代码后,我仍然想知道为什么goroutines不止一次地使用同一行?我猜它正在努力完成工作。这是我的代码packagemainimport("log""bufio""fmt""encoding/csv""encoding/json""io""os""sync")typeIMDBDataModelstruct{Colorstring`json:"color"`DirectorNamestring`json:"director_name"`NumCri

Golang 并行

我是Golang的新手,正在尝试了解并发和并行。我阅读了下面提到的关于并发和并行的文章。我执行了相同的程序。但没有得到相同的(混合字母和字符)输出。首先获取所有字母,然后获取字符。似乎并发不工作,并行不工作。文章说添加runtime.GOMAXPROCS(4)来实现并行。为什么我没有得到平行输出?我正在使用4核CPU系统和GO版本1.8.2https://www.goinggo.net/2014/01/concurrency-goroutines-and-gomaxprocs.html我知道如果我们添加Sleep然后我可以看到并行输出,按照并发概念。但是Parallelism是说如果系

http - goroutine 在请求时很快阻塞了 http 服务器

goroutine在请求请求时阻止了http服务器以下代码即将被屏蔽在一个设备管理功能中,通过访问httpRESTful接口(interface)判断设备是否在线,30s访问1000个设备,当前程序大致如下,看goroutine数量不是很多,但是很快程序不会Move,cpu、内存不会占用太高packagemainimport("fmt""net/http""runtime""time")funca(){b()//.....}varbb=0funcb(){fmt.Printf("b:%d\n",bb)bb++resp,err:=http.Get("http://www.baidu.com

go - 关闭一个 Go channel ,并同步一个 Go 例程

我无法在go中终止我的WaitGroup,因此无法退出范围循环。谁能告诉我为什么。或者更好的方法来限制go例程的数量,同时仍然能够在chan关闭时退出!我见过的大多数示例都与静态类型的channel长度有关,但此channel会因其他进程而动态调整大小。示例中的打印语句(“DONE!”)显示testValProducer打印了正确的次数,但代码从未到达(“--EXIT--”),这意味着wg.Wait仍然以某种方式阻塞.typeTestValContainerchanstringfuncStartFunc(){testValContainer:=make(TestValContainer

go - 在 go channel 上选择内部范围

我正在关注thispost并行化我的应用程序。我需要定制这段代码:funcsq(done我不完全理解caseout这行.我可以看到它说如果n有一个值,然后将其平方并发送到channel中,但我不明白为什么。是否select只拿第一个true案件?是否可以改写:forn:=rangein{select{casen:out无论如何,我需要替换行caseout通过函数调用。我已将其更改为以下内容:out:=make(chanstructs.Ticket)gofunc(){deferclose(out)forurl:=rangeinputChannel{select{caseurl:data,

'A Tour of Go'的Crawl例子goroutine没有生效

正如“ATourofGo”的Crawl示例中提到的命中,我修改了Crawl函数,只是想知道为什么“goCrawl”无法生成另一个线程,因为只找到一个url被打印出来。我的修改有问题吗?如下列出我的修改,//Crawlusesfetchertorecursivelycrawl//pagesstartingwithurl,toamaximumofdepth.funcCrawl(urlstring,depthint,fetcherFetcher){//TODO:FetchURLsinparallel.//TODO:Don'tfetchthesameURLtwice.//Thisimpleme

Goroutines 和消息去重

所以我有一些事件队列和几个goroutine,它们在无限循环中从相应的队列中获取事件,处理它们,然后将结果发送到channel中。不同的队列可能会给你相同的事件,所以我需要确保每个事件都被发送到channel一次,并且该消息在另一个队列中的任何出现都将被忽略。我认为这更像是一个架构问题,但我不知道如何正确处理。我当前代码的简化版本如下。获取和处理传入事件的Goroutine看起来有点像这样:func(q*Queue)ProcessEvents(handlerHandler){lastEvent=0for{events=getEvents(lastEvent)for_,e:=rangee

go - 使用 slack bot 处理多个数据竞争

我正在开发一个slack机器人作为我的第一个golang项目,虽然这个特定的机器人命令的功能很好,但它可能会随机出现panic并抛出错误。我能够确定我正在进行数据竞赛,特别是我的两个go例程。但是,我很难确定如何修补它们,或者执行互斥锁是否是处理共享变量的正确方法。我正在尝试确定问题是否出在我的result变量上,该变量被分成多个channel,每个channel都由go例程处理,或者是否是os.exec包使用我的缓冲区变量来运行stdout和stderr修改的命令。下面是代码和数据竞争示例。packagerebootimport("bytes""encoding/json""fmt"

go - 解决 goroutines 死锁

我一直在尝试解决我在Golang并发中遇到的这个简单问题。我一直在搜索所有可能的解决方案,但没有发现任何特定于我的问题(或者我可能会错过一个)。这是我的代码:packagemainimport("fmt""time")funcproducer(chchanint,dtime.Duration,numint){fori:=0;i它打印错误:fatalerror:allgoroutinesareasleep-deadlock!goroutine1[chanreceive]:main.main()D:/Code/go/src/testconcurrency/main.go:23+0xcaex