草庐IT

延迟任务

全部标签

Golang例程每分钟任务

如何打发time.Sleep(time.Until(nextExecute))?这是一个旧的session清理任务,需要作为后台任务每分钟执行一次。工作正常,但在SIGINT之后,所有程序仍在等待时间。sleep...知道如何消磨时间。sleep或备用例程代码吗?funcSessionCleanupTask(){varquit=make(chanos.Signal)signal.Notify(quit,syscall.SIGHUP,syscall.SIGINT,syscall.SIGTERM,syscall.SIGQUIT)//kbdloss,ctrl+c,terminate,quit

go - 仅在合并到 master 时运行任务

我使用以下配置,它按预期工作,它在每个PR上运行命令或合并到主服务器,现在我想进行一些集成测试,我想仅在合并到主服务器时运行,所有PR都应该保持不变(并像以前一样运行以下配置)。这里的细微差别是,对于集成测试,我需要其他docker图像和不同的运行命令来执行(应该只在合并到master时执行),是否可以使用CircleCI来完成?p>#GolangCircleCI2.0configurationfileversion:2jobs:build:docker:#specifytheversion-image:circleci/golang:1.11working_directory:/go

google-app-engine - App Engine 任务队列创建一批队列项并在 go lang 中每 10 秒执行一次

由于使用内部代码的第三方API的某些限制(第三方API每分钟有1000个API调用),我想创建一批队列项并每10秒执行一次。但我不知道如何使用任务队列在AppEngine中实现给定的要求。或者可以使用任务队列推送创建批处理吗? 最佳答案 TaskQueueTask有一个Delaytime.Duration以及ETAtime.Time字段,可用于创建和延迟任务.相信你可以重用thetopexample但在调用taskqueue.Add(c,t,"")之前设置其中一个字段 关于google-

google-app-engine - 在 appengine 中使用 go 语言的 TTFB(延迟)太慢

我正在appengine中测试golang。但是react太慢了。我用chrome检查了一下,发现问题是“等待(TTFB)”源代码非常简单,官方示例(https://github.com/GoogleCloudPlatform/appengine-try-go)。怎么了?这正常吗? 最佳答案 本地测试性能与生产性能无关。您所看到的没有任何问题。通常第一个请求比后续请求慢,因为AppEngineSDK执行文件系统扫描、编译和首次加载以及执行应用程序代码的init()函数包。您看到的是1秒的Waiting(TTFB)时间,它代表Time

go - 使用 time.AfterFunc 在 golang 中按时间间隔执行重复性任务,只是一个示例

我只想在Go中做重复的后台任务,使用time.AfterFunc,但似乎逻辑有问题。输出只是:间隔调用间隔调用但如果一切正常,至少要调用该函数5次。packagemainimport("fmt""time""os""os/signal")typeTimerstruct{Queuechan*TimeCall}funcNewTimer(lint)*Timer{timer:=new(Timer)timer.Queue=make(chan*TimeCall,l)returntimer}typeTimeCallstruct{timer*time.Timercallbackfunc()}func(

asynchronous - 在golang中,如何编写一个为下一阶段引入延迟的流水线阶段?

我正在关注https://blog.golang.org/pipelines文章实现了几个阶段。我需要其中一个阶段在事件传递到管道的下一阶段之前引入几秒钟的延迟。我对下面的代码的担忧是,它会在传递事件之前产生无限数量的time.Sleep()例程。有没有更好的方法来做到这一点?谢谢!funcfooStage(inChan 最佳答案 您可以使用另一个channel来限制您的循环能够创建的事件goroutine的数量。constnumRoutines=10funcfooStage(inChan

go - 使用 channel 来调度任务以进行例程

我正在编写一个程序来渲染图表。Todo所以我正在搜索所有文件并希望将它们异步分派(dispatch)到go例程以并行处理它们。但是我想我误解了channel的概念。files:=umlFiles("uml")//listofstringsqueue:=make(chanstring)fori:=0;i这将在处理完前4个文件后陷入死锁,但不会继续处理其余文件。我可以使用channel将任务分派(dispatch)给正在运行的go例程并在所有任务完成后停止它们吗?如果是这样,上面的代码有什么问题?曾经到达这里:how-to-stop-a-goroutinego-routine-deadlo

Java 延迟读取 XML 文件?

我想知道如何在Java中延迟读取不适合内存的大型XML文件。假设文件格式正确,我们不必首先检查它。有人知道如何在Java中执行此操作吗?这是我的假文件(真实文件是维基百科转储,大小超过50Gb):somedata.......MOREDATA........我正在用一个XML库尝试这个,它应该能够做到这一点,但它正在将整个东西加载到内存中>:ODOMParserdomParser=newDOMParser();//Thisissupposedtomakeitlazy-loadthefile,butit'snotworkingdomParser.setFeature("http://ap

java - ANT build.xml 删除目录的任务不起作用

我有一个xml脚本,用于根据这种结构构建项目。来源src文件和包子目录rsrcbuild.xml在构建出src文件夹后,在rsrc中创建了一个构建和lib文件夹来源src文件和包子目录rsrcbuild包子目录图书馆build.xml一切正常后,build文件夹中充满了.class文件,在它们的包子目录中。在lib文件夹中,分发.jar有它的位置。现在针对我的问题,我写了这个名为“clean”的目标:应该删除构建文件夹、其子文件夹和内容。$Build定义为:基目录为basedir="."但是什么都没有被删除,我做错了什么。最好的问候斯特凡(如果您需要其他信息,请询问)编辑:如果我用“a

sql-server - SSIS XML XSLT 任务内存不足

我正在BIDS2005中开发一个包,该包以针对非常大的输入文件的XML(XSLT)任务开始,并不断收到以下错误[XMLTask]Error:Anerroroccurredwiththefollowingerrormessage:"Exceptionoftype'System.OutOfMemoryException'wasthrown.我的工作站是Win764位-16GIGRam-i78核处理器3.5gHZ。我在此过程中运行任务管理器,它在运行期间最多只能使用大约7.5gigs的ram,直到它因错误而崩溃。我正在针对我的本地SQL2008R264位实例运行。该包在BIDS中配置为以64