草庐IT

线程队列

全部标签

multithreading - go 语言 web 框架设计线程明智

GOnet/http库的线程设计是怎样的?我听说thistalk几天前,我真的很好奇GO开发人员如何在线程方面实现他们的Web框架设计。我知道node.js使用1个计算线程读取事件和一个I/O线程池。ASP.NET每次调用使用一个线程...GO如何处理C10K问题? 最佳答案 如documentation中所述,net/http服务器为每个连接使用一个goroutine。. 关于multithreading-go语言web框架设计线程明智,我们在StackOverflow上找到一个类似的

go - 正在将标准库日志重定向到 logrus 线程安全

我正在使用logrus我的Go项目中用于结构化日志记录的库。我的logrus配置如下://GlobalvariableforloggingvargLog=&Logger{moduleName:ModuleName,logrus:logrus.New()}typeLoggerstruct{moduleNamestringlogrus*logrus.Logger}funcSetupGlobalLogger(logPrefixstring,logModestring)error{iflogMode=="file"{logFilePath:=fmt.Sprintf("var/%s.log",v

multithreading - goroutine 或多线程在 golang 中不起作用

我试图在golang中实现多线程。我能够实现goroutines,但它没有按预期工作。下面是我准备的示例程序,functest(sstring,fo*os.File){vars1[105]intcount:=0forx:=1000;x输出-good0bye0bye0bye0bye0good1bye1bye1bye1bye1good2bye2bye2bye2bye2....等等。上面的程序会创建一个文件,并在文件中写入“Hello”和“bye”。我的问题是我正在尝试创建5个线程并希望使用不同的线程处理不同的值。如果你会看到上面的例子,它打印了4次“bye”。我希望使用5个线程输出如下所示

multithreading - Golang线程不是每次都执行

这个问题在这里已经有了答案:Nooutputfromgoroutine(3个答案)Goroutinedoesnotexecuteiftime.Sleepincluded(1个回答)关闭4年前。所以,我正在测试Golang。我知道fmt.Println不是线程安全的。所以,我尝试了sync.Mutex。程序如下:functhreder(mux*Mutex,iint){mux.Lock()fmt.Println("Iamthread:",i)mux.Unlock()return}funcmain(){m:=&Mutex{}fori:=0;i我期待300行输出。但是,我得到80-90行。我哪

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

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发送看起来是原

google-app-engine - GAE Golang 实现一些独特的请求队列?

我有一个GoogleAppEngineGo应用程序正在处理来自第三方服务器的实时通知。这些通知或多或少需要在现场记录和处理。然而,第三方服务器有一个坏习惯,即同时发送两个请求,有时彼此相隔1毫秒-速度太快甚至无法使数据存储/内存缓存写入指示信号量。我想知道是否有一种方法可以巧妙地处理这种并发请求?理想情况下,我希望将它们放在某个堆栈上,这样可以保证一次处理一个项目。在GAEGolang中可以实现这样的功能吗? 最佳答案 为具有较短超时时间的消息的唯一标识符添加内存缓存(实际上并不重要)。如果添加成功,处理消息。

google-app-engine - GAE (go) 推送队列率未强制执行

我正在尝试让推送队列中的某些任务以大约每秒一次的速度执行。下面是我如何定义我的queue.yamlqueue:-name:defaultrate:1/sbucket_size:1max_concurrent_requests:1我有一个处理程序(用于/tasks/readalerts),它将任务排入队列:t:=taskqueue.NewPOSTTask("/tasks/readalerts",map[string][]string{})if_,err:=taskqueue.Add(context,t,"");err!=nil{context.Errorf("%v",err)}一旦我访问

google-app-engine - 从任务队列中解码正文响应

我正在使用go和google任务队列来创建一些同步作业。我成功地将数据传递给工作方法,但我无法解码数据以使用它。我尝试了不同的方法,但我遇到了一个解码错误errum&json.SyntaxError{msg:"invalidcharacter'i'inliteralfalse(expecting'a')",Offset:2}这就是我将数据发送到队列的方式keys:=make(map[string][]string)keys["filenames"]=req.FileNames//[]stringt:=taskqueue.NewPOSTTask("/deletetask",keys)_,

C#在工作线程中更新UI界面上的控件

C#的应用程序开发中,我们经常要把UI线程和工作线程分开,防止界面停止响应。  同时我们又需要在工作线程中更新UI界面上的控件,下面介绍几种常用的方法线程间操作无效界面上有一个button和一个label,  点击button会启动一个线程来更新Label的值privatevoidbutton1_Click(objectsender,EventArgse)      {        Threadthread1=newThread(newParameterizedThreadStart(UpdateLabel));        thread1.Start("更新Label");      }