草庐IT

goroutines

全部标签

go - 使用 goroutine 的多线程

我正在尝试使用Go来自动化我的侦察工具。到目前为止,我可以在kali(Nikto/whois)中运行两个基本工具。现在我希望它们并行执行,而不是等待一个函数完成。阅读了一下之后,我开始知道这可以通过使用goroutines来实现。但我的代码似乎不起作用:packagemainimport("log""os/exec""os""fmt")varurlstringfuncnikto(){cmd:=exec.Command("nikto","-h",url)cmd.Stdout=os.Stdouterr:=cmd.Run()iferr!=nil{log.Fatal(err)}}funcwho

go - 为什么调用 goroutines 的顺序和方式很重要?

我正在尝试理解goroutines。在下面的示例中,为什么1)--4)的行为不同?参见https://play.golang.org/p/_XXZe47W53vpackagemainimport("fmt""time")funcsend(xint,chchanint){ch1//gofmt.Println(1//gofmt.Println( 最佳答案 您看到错误是因为读取不是发生在goroutine内部,而是发生在主线程中。行:gofmt.Println(正在主线程中评估参数,一旦成功,它将使用已解析的参数在goroutine中运行

go - channel 什么时候阻塞 goroutine

如果我定义一个没有缓冲区的channel并向其中写入一个数据,它会立即阻塞(以便内核将寻找另一个未阻塞的goroutine从该channel读取),还是继续执行并在下一次时阻塞某些代码在尚未读取时尝试再次写入channel?下面是我为了研究这个问题写的两段代码。代码1:packagemainimport"fmt"funcmain(){c:=make(chanint)gofunc(){fori:=0;i输出是这样的:number0insertedintochannelnumberpopedfromchannel0numberpopedfromchannel1number1inserted

go - 使用 goroutine 运行 cmd.Wait() 时的错误处理

我试图在Golang中调用一些外部命令非阻塞,所以我使用了cmd.Start()和gocmd.Wait()虽然我不需要等待命令成功运行,但我运行cmd.wait()的原因是因为文档提到Wait释放与Cmd关联的任何资源”所以我不想造成资源泄漏。但是这种用法会导致linter报错,提示我没有处理错误。Errorreturnvalueof`cmd.Wait`isnotchecked(errcheck)gocmd.Wait()如何处理gocmd.Wait()的错误?或者,如果我不运行gocmd.Wait(),会不会导致资源泄漏?添加:我使用gocmd.Wait()的一个原因是,如果我不使用它

go - 如何理解这个例子中的 goroutines 执行?

我正在尝试了解go例程及其工作原理。在下面的示例中,我有两个go例程,每个例程都通过channel发送一些消息。我期待channelch将首先发送消息,但为什么goreadword(ch)在gotimeout(t)之后执行。如果我在main函数中更改goroutines调用的顺序,那么readword(ch)将首先执行。我对goroutines感到非常困惑?有帮助吗?funcreadword(chchanstring){fmt.Println("Typeaword,thenhitEnter.")varwordstringfmt.Scanf("%s",&word)ch

go - 是否可以按输入顺序收集 goroutine 结果?

这个问题在这里已经有了答案:HowtocollectvaluesfromNgoroutinesexecutedinaspecificorder?(2个答案)关闭5年前。我认为我的结果顺序应该与输入相同,是否可以在goroutine中使用?我是这样实现的:packagemainimport"fmt"import"time"funcworker(idint,jobs运行它here

linux - 无法在 Linux 上的 goroutine 中运行 go web serve (Mint)

我正在尝试在我的go应用程序中启动一个网络服务器。当我在Windows上运行我的代码时,一切都按预期工作。应用程序运行它启动web服务器,然后等待。在Linux上,它似乎做同样的事情,只是我无法访问Web服务器。如果我在不使用goroutine的情况下启动Web服务器,服务器会正​​常工作,只有当我使用goroutine时它​​才会失败。packagemainimport("fmt""log""net/http")funcmain(){//gostartWebServer()//ThisonlyworksonWindows.//startWebServer()//Thisworkson

multithreading - 自同步 Goroutines 以死锁告终

我有一个压力测试问题,想通过Go中的简单同步来解决。到目前为止,我已经尝试查找关于我在Go中同步的特定用例的文档,但没有找到合适的文档。更具体一点:我必须完成一项任务,我必须在主例程中启动大量线程(在此示例中仅使用两个线程进行说明)。所有被启动的worker都应该以无序的方式自己准备一些初始化Action。直到它们到达一个小的命令序列,我希望所有的goroutines一次执行它们,这就是为什么我想要让goroutines相互同步。对我的任务来说非常重要的是,通过实例化所有其他goroutine的主例程的延迟不会影响工作人员执行的真正并行性(在注释中的标签#maximumparallel

io - 中止来自另一个 goroutine 的 Read() 调用

我在IMAP服务器上工作,其中一项操作是升级连接以使用TLS(通过STARTTLS命令)。我们当前的架构有一个goroutine从套接字读取数据,解析命令,然后通过channel发送逻辑命令。另一个goroutine从该channel读取并执行命令。这在一般情况下效果很好。但是,在执行STARTTLS时,我们需要停止当前正在进行的Read()调用,否则Read()将使用来自TLS握手的字节。我们可以在两者之间插入另一个类,但是那个类将在Read()调用中被阻塞,我们遇到了同样的问题。如果网络连接是一个channel,我们可以添加另一个信号channel并使用select{}block来

multithreading - App Engine Channel API 的线程安全/原子性

当我尝试使用GoogleAppEngine的ChannelAPI从两个或多个goroutines和/或任务队列发送消息时会发生什么?例如gochannel.Send(context,clientID,"Hello")gochannel.Send(context,clientID,"World")我知道在GAEGo中,所有goroutines都被多路复用到一个线程上。然而,这仍然允许在I/O期间进行抢占,并且channel发送可能符合I/O的条件。GAE开发服务器似乎序列化了所有请求,所以我没有看到任何channel发送重叠。生产服务器似乎允许一些请求并发,但channel发送看起来是原