草庐IT

PHP异步任务

全部标签

go - 在 Web 应用程序中运行计划任务

我想每5分钟运行一次任务来更新我网站上的统计数据而不阻塞HTTP服务器。我刚刚添加了带有工作人员示例的基本HTTP服务器逻辑。如果我像这样添加多个任务,这是否被认为是不好的做法,还是有更好的方法?packagemainimport("fmt""net/http""time")funcHome(whttp.ResponseWriter,r*http.Request){fmt.Fprintf(w,"Homepage")}funcschedule(ffunc(),intervaltime.Duration)*time.Ticker{ticker:=time.NewTicker(interva

go - 如何并发优化大型递归任务

我有一个chron任务要在Golang中以最佳方式执行。我需要在sellers中以JSON格式存储来自Web服务的大数据将这些sellers保存到数据库后,我需要浏览另一个带有sellersID参数的大型JSON网络服务,以保存到另一个名为customers的表.每个customer都有一个初始状态,如果这个状态已经从web服务的数据改变(n°2)我需要将差异存储在另一个表中changes以获取更改历史记录。最后,如果变化等于我们的条件,我将执行另一项任务。我目前的操作varwgsync.WaitGroupaction.FetchSellers()//fetchlargeJSONand

asynchronous - 具有异步 goroutines 的 Kafka 消费者

我正在为我的消费者使用sarama(https://github.com/Shopify/sarama/)和Kafka0.8.0。这是我的代码的样子:consumerLoop:for{select{caseevent:=我正在使用缓冲channel(c.sem)来控制一次可以运行多少个processJobgoroutine。这就是我控制消费者的并发/速度的方式。我在使用这种方法时遇到的问题是,如果我需要更改并发性,我必须关闭使用者并重新启动它(channel缓冲区大小是一个命令行标志)。我记录了已处理的偏移量,我必须查看我的日志以确定处理了哪些偏移量以及我希望消费者从哪里恢复。我想要一

c# - 您将如何使用 Scala 的异步使多个异步请求超时?

我不了解Scala,但我很好奇它的异步功能(类似于C#的)。您将如何将此go代码转换为Scalaasync?http://talks.golang.org/2012/concurrency.slide#47c:=make(chanResult)gofunc(){c 最佳答案 这是如何完成的草图(未经测试;我不声称这是最佳解决方案)://IassumethattheWeb/Image/VideofunctionsreturninstancesofFuture[Result]valf1=Web(query)valf2=Image(que

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)_,

javascript - Go 语言构建器/任务运行器

我正在创建一个小型SPA框架(可能是一个全功能框架)。前端基于原生javascript(包括ES6功能和网络组件)。后端是用Go编写的。这是我的需求列表,我想自动执行:缩小我的javascript文件将ES6代码转译为ES5(使用类似babel.js的东西)Polyfill我的网络组件有没有不使用node.js就可以实现的方法?是否已经有go包可以让这3件事发生,并且使用“简单”的grunt/gulp类方式?我想避免安装node.js、npm、bower...等。在我(不是很secret)的观点中,使用那些node.js工具使我的应用程序变得一团糟,给我的应用程序文件夹增加了很多不必要

database - Golang 代码的运行速度真的比 PHP 中的相同代码慢

Golang新手,昨天我开始使用Golang并编写了一些实际用PHP编写的代码。我只是想看看性能上的差异。我在PHP中做完全相同的事情,响应在http请求中完全相同,但Golang的执行速度非常慢,即使在编译之后也是如此。我试图了解我在Golang中使用的哪些东西不应该使用,以及我如何才能提高这段代码的性能。我知道遍历映射很慢,但是PHP使用散列映射来实现多维数组。我可以保证我使用的sql查询是从PHP粘贴的完全相同的副本,机器相同,并且两个代码中的循环数相同。packagemainimport("database/sql""encoding/json""fmt"_"github.co

设置表格以重定向到提交时的当前页面(SilverStripe/PHP)

我为SilverStripe站点有一个注册表单,该网站处理服务器端上的所有内容。最初,它只会在主页上,所以我工作的设置很好。但是随后的需求发生了变化,也需要出现在子页面上的表格。除了我为什么设置的内容,表格总是提交到主页外,一切仍然有效action范围。最初,action参数为“/家庭/提交”。我将其更改为接受一个变量,该变量返回当前页面URL并通过制作称为称为的函数来附加“/提交”Link(请参阅下面的代码)。这似乎有效,并将正确的URL放入action范围。但是,当您点击“提交”按钮时,该表格仍将用户发送回主页,这不是我想要的。我希望他们留在表单上的当前页面上(无论是主页还是任何子页面)。

multithreading - 半异步代码逻辑

我正在努力找出一种可行的设计,将同步流与异步行为混合在一起。我有4个组件:播种者worker出版商更新者我唯一的限制是,一旦Seeder播种数据,它必须被阻止,直到Updater没有完全完成所有任务的处理。前3个组件可以很容易地同步,但更新程序必须并行工作,否则将永远无法完成任务。所以流程是:播种机->worker->发布者->更新者-->播种者->worker->发布者->更新者...并且这个流必须永远旋转。播种和更新是针对数据库的。不幸的是,这个特定的数据库不允许不同的设计。我最好的办法是使用sync.WaitGroup来同步Updatergoroutines并将其他所有内容保持在

go - curl php为golang api返回状态代码0

我已经在golang中创建了一个getListapi。现在我正在尝试使用php-curl从我的php函数调用getListapi。我正在从我的php函数发出数千个请求。然而,大约15k请求得到了正确处理,但在15k-20k(数量不同)和更多请求之后,CurlCURLINFO_HTTP_CODE返回0并且responseis""并且curl_error返回空字符串。curl_errno返回7我的golanggetListapi很简单。它从数据库中获取数据并将其返回。它不包含任何goroutines。我不明白为什么在15k-20k请求之后它开始给我空响应。不知道是curl-php问题还是g