草庐IT

Goroutine-safe

全部标签

go - 如何分析多个 goroutine

我想分析一个用Go编写的服务器。我正在使用“net/http/pprof”,但默认行为完全没用,因为它似乎只分析运行服务器的goroutine,该服务器为分析数据提供服务。 最佳答案 我的服务器被围攻了。对于1000个并发用户,我得到了我想要的分析数据。 关于go-如何分析多个goroutine,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/34710112/

在单独的 goroutine 中显示进度的 HTTP 服务器

假设我有一个在服务器上运行的长时间运行的Go程序,用户有时需要查看其结果(统计信息)。我们当然可以创建一个屏幕session并让他通过SSH登录,重新附加到session等,但这似乎不太实用。作为一个更好的选择,我想启动某种嵌入式HTTP服务器,该服务器应在8081等端口上监听,并在请求时以文本(或JSON或XML或其他)形式返回信息。基本上它应该只是组成一个字符串并通过HTTP/1.1返回它。它显然应该在自己的goroutin中运行(在后台)。保证服务器收到低流量(例如,没有同时请求)那么可能有一些现成的东西? 最佳答案 这将需要

go - 为什么我通过循环创建goroutine会出现这种情况?

请帮帮我。我有block代码,它使用迭代来获取map的元素,并使用这个元素在Linux机器上的端口上创建一个监听器,但它的执行超出了我的预期。代码如下:varsrvs=map[string]struct{idinttimezonestringconnCfgstringconnnet.Conn}{"BrazilEastSrv":{id:1,timezone:"Brazil/East",connCfg:"127.0.0.1:9007"},"AustraliaDarwinSrv":{id:2,timezone:"Australia/Darwin",connCfg:"127.0.0.1:900

go - 无法无限期地写入一个 goroutine 并从另一个 goroutine 中读取

我正在学习围棋,但在使用goroutines时遇到了问题。这是我的代码packagemainimport("fmt""sync""time")varcounter=0varwg=sync.WaitGroup{}funcmain(){ticker:=time.NewTicker(time.Second)gofunc(){forrangeticker.C{//wg.Add(1)//deferwg.Done()counter++fmt.Println(counter)//wg.Done()}}()ticker2:=time.NewTicker(time.Second*2)wg.Add(1)g

go - 带有 channel 的Goroutine的行为

下面给出的代码输出有些混乱,请帮助我理解通道和goroutine的行为以及如何执行实际上发生了。我试图理解程序的流程,但是执行了“调用goroutine”之后的语句,即使goroutine被调用了,稍后执行goroutines中的语句,在第二次“调用goroutine”时,行为不同,并且打印/程序流程的顺序发生了变化。以下是代码:packagemainimport"fmt"funcmain(){fmt.Println("1")done:=make(chanstring)gotest(done)fmt.Println("7")fmt.Println(上面代码的结果:17238109465

go - 当 parent 返回时停止子 goroutine

这个问题在这里已经有了答案:Stopgoroutineexecutionontimeout(3个答案)关闭3年前。我们有一个生成父goroutine的主go例程,父goroutine又生成一个子go例程。即使在父goroutine返回后,子goroutine仍然运行。这会导致goroutine泄漏。我们如何避免这种情况?下面我添加了一个代码片段来模拟以下内容这里的子goroutine可以是任何一个长时间运行的进程,比如数据库查询、api调用等Programoutput:Inmainfunction-1Startingparentfunction-2Startingchildfuncti

performance - Golang goroutine 在添加并发时变慢

我正在研究golang和goroutine的使用。使用此示例代码,在我具有4个逻辑CPU的PC上,我无法理解为什么我没有任何性能提升。如果我添加并发,那么它所花费的时间往往会比没有并发的原始时间慢。2017/10/2713:57:17Starting1threads2017/10/2713:57:27Idroutine:0rate:232.5581402017/10/2713:57:27Currenttotalratewas232.56K/s2017/10/2713:57:27Starting1threads2017/10/2713:57:37Idroutine:0rate:357.1

go - 如果调用的函数来自不同的包,如何同步 goroutine?

为了学习如何在Go中构建Web应用程序,我创建了一个小型Web应用程序,我在其中使用了Gorillamux,我主要在包main、handlers、model、structs下面。我想在浏览文档时使用goroutines我开始知道我需要使用sync包和gofun()。我尝试如下所示在同一个包中使用它并且工作正常。但是,如果调用的函数来自不同的包,如何同步goroutine?//samepackage:workingpackagemodelsimport("fmt""sync")varwgsync.WaitGroupfuncFunc1()(string,error){lexpiry:=Re

带有 channel 的循环中的 goroutine

已结束。此问题是notreproducibleorwascausedbytypos.它目前不接受答案。此问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭4年前。Improvethisquestion注意:GetTaskQueue()返回一个全局变量,其结构为typeTaskQueuestruct{chchanintwg*sync.WaitGroup}channel用于限制goroutine的数量,goroutine的最大数量设置为3。我的期望是所有ts都应该匹配tasks。但是,Dominium

json - Golang 运行时 : goroutine stack exceeds 1000000000-byte limit

当我尝试Marshall嵌套结构的对象时出现此错误。我的结构看起来像:typeBlockchainstruct{blocks[]Block`json:"blocks"`difficultyint`json:"difficulty"`}typeBlockstruct{indexint`json:"index"`timestampstring`json:"timestamp"`datastring`json:"data"`previousHashstring`json:"previousHash"`hashstring`json:"hash"`nonceint`json:"nonce"`}