草庐IT

管道化

全部标签

go - 尝试使用 channel 获取 FIFO 处理管道

我正在尝试使用一个简单的假示例在Go中编写顺序处理管道。它遍历一个假目录并运行一些转换。因此,它们之间共享一个字符串channel。在一个函数写入数据后,第二个函数读取它。在我看来,当我在WalkFakeDirectory函数前面放置一个go关键字时,它只起作用并且也按顺序起作用,如下面的代码示例(playground)所示。如果有人能解释一下这是如何工作的,我们将不胜感激?packagemainimport("fmt""strings""sync""time")funcmain(){done:=make(chanint)path:=make(chanstring)deferclose

go - go 语言中的函数管道

是否有可能在go语言中创建函数管道,其中一个函数的输出直接约定为另一个函数的输入。如果不清楚并且您需要更多信息,请在评论中讨论。其他函数式语言提供了一些结构,例如在javascript中是then和promises,在java中它们使用andThen和lambdas,对于c#,它是FunctionExtensions。像unix这样的shell程序也提供了buitin方法叫做pipes|funcprocessA(testTestObj){//dosomethingreturntest}funcprocessB(testTestObj){//dosomethingreturntest}f

go - GO 应用程序在管道中时如何提示用户输入

我的GO应用程序需要从管道接收输入,同时必须提示用户输入密码。因为我不喜欢在命令参数中设置密码,所以我想像sudo命令一样实现它。如果我尝试从标准输入读取,我将收到最后一个命令输出作为密码(很明显)。我也尝试过使用这个库https://github.com/howeyc/gopass但它只从标准输入中读取。有没有办法在GO中做到这一点? 最佳答案 你不能,这与go无关。当您通过管道传输到一个程序时,您是将一个程序的标准输出定向到该程序的标准输入,而不是tty(标准输入通常附加到什么)。一个程序只能获得一个标准输入,因此您不能既接收来

go - 如何使用 go 从端口 80 无缝地管道/转发到端口 XXXX?

我有一堆网站在一台服务器(单一IP)上运行,它们都在高端口上运行,所以我不需要root来运行它们。当有人从一个网址访问时,比方说,http://address001.com/,我想将数据从端口4444无缝地传输到发出这个请求的人,如果有人访问http://address002.com/我想从端口5555传输数据。我将如何在Go中执行此操作?到目前为止,我有一个如下所示的处理函数:funchome(whttp.ResponseWriter,r*http.Request){ifstrings.Contains(r.Host,"address001"){//???}}

mongodb - 如何使用 MGO 聚合管道查找符合特定条件的所有嵌入文档

假设我在MongoDB的Groups集合中有以下数据[{“Group”:{“_id”:1,“Requests”:[{“_id”:1,“name”:”RequestA”}.{“_id”:2,“name”:”RequestB”}]}},{“Group”:{“_id”:2,“Requests”:[{“_id”:3,“name”:”RequestC”}.{“_id”:4,“name”:”RequestD”}]}}]另外,假设我有以下功能funcGetRequests(requestIDs[]string)(Request[]error){//NEEDTOIMPLEMENTW/MGO}有没有办法

mongodb - 如何通过管道函数获取子字段值

我正在编写代码,用于在golang中从mongodb接收数据。我的代码如下:typeDataContentstruct{Createtime.Time`bson:"create"`Descstring`bson:"desc"`}typeDatastruct{Idbson.ObjectId`bson:"_id,omitempty"`Descstring`bson:"desc"`ContentDataContent`bson:"content"`}funcget()error{result:=[]Data{}coll:=session.DB(“”).C(“aaa”)project:=bso

linux -/dev/ttyACM0 Postfix 管道时文件不存在

当我以普通用户身份手动运行脚本时,一切正常。但是如果收到一封电子邮件并将其通过管道传输到Go脚本中,我将无法打开串口,因为文件不存在。postfix12391025013:20?00:00:00pipe-nwatchParadox-tunixflags=Fuser=watchargv=/usr/local/bin/watch-paradoxwatch12401239013:20?00:00:00/usr/local/bin/watch-paradox脚本在已添加到dialout组的watch用户下运行,为了确定,postfix用户也在dialout中。在我的脚本中,我运行了ls-la命

go - 如何使用命名管道处理进程输出

我正在尝试从tmux中正在运行的进程设置管道,以便逐行处理其输出。我看过thisguidetopipetheoutputofatmuxsessiontostdout和thisarticleabout(named)pipesingo.我已经尝试了很长一段时间,但仍然没有得到任何值得注意的结果。如果有任何关于如何设置该管道的想法,我将不胜感激,理想情况下,我可以按行对其进行范围调整。非常感谢 最佳答案 这是我找到的解决方案here(谢谢Malcolm)funcReadln(r*bufio.Reader)(string,error){va

go - 在 golang 中准备好后从 stdout 管道读取

我正面临一个奇怪的golang问题。以下代码将阐明:packagemainimport("os/exec""io""fmt""os")var(pwio.WriteCloserprio.ReadCloser)funcmain(){term:=exec.Command("/bin/sh")//Getstdinwriterpipepw,_=term.StdinPipe()pr,_=term.StdoutPipe()term.Start()run("cd~")pwd:=run("pwd");//Dosomethingwithpwdoutput...term.Wait()}funcrun(cst

go - 实现 worker 功能的管道

我正在实现一个由多个通过channel连接的工作函数组成的管道。它们都得到(in,outchaninterface{})作为输入(每个函数接收前一个函数的out作为in)我不能保证out会在每个函数结束时关闭,所以我想知道我应该如何检查前一个函数是否完成了它工作。我从这样的事情开始:funcExecutePipeline(jobs...job){out:=make(chaninterface{},10)for_,val:=rangejobs{in:=outout:=make(chaninterface{})goval(in,out)}}我正在考虑以某种方式使用WaitGroup来使用函