草庐IT

定时任务调度

全部标签

multithreading - Golang 线程池调度程序的目的和顺序

我刚刚用go写完了一个简单的代理应用程序:代码从一个接口(interface)获取UDP数据包,加密数据,然后使用TCP将其发送到另一个接口(interface)。目前,我正在使用三个goroutines:一个用于接收数据,一个用于加密,一个用于发送数据。我刚刚开始尝试寻找提高代码效率和速度的方法。首先,我想为每个需要加密的数据包创建一个新的goroutine,但在阅读了以下两篇博文后,我明白这不是正确的做法:http://marcio.io/2015/07/handling-1-million-requests-per-minute-with-golang/http://nesv.g

go - 在使用 GOMAXPROCS = 256 运行无限循环 goroutines 时理解 golang 的调度程序

我正在玩Go,在我的20158核MacBookPro上运行go1.7.3。尝试了解runtime.GOMAXPROCS设置为其最大值(256)并启动相同数量的goroutine时goscheduler的工作原理,每个goroutine都运行一个无限循环。我的假设是goruntime会产生runtime.GOMAXPROCS数量的操作系统线程(即256个线程)并在这些线程中运行我的goroutines。我期待下面的代码打印出256个1:funcmain(){procs:=256runtime.GOMAXPROCS(procs)fori:=0;i此代码每次运行时都会打印不同数量的1。大多数

gocron 创建任务的多个实例

我在使用这个包的脚本中遇到问题:"github.com/jasonlvhit/gocron"我在找不到错误后写了这个小测试脚本,结果是按预期执行的cronjobs数量是预期的两倍:funcmain(){fori:=0;i运行它给了我这个输出:——▶gorun*.gostillrunning...0stillrunning...0stillrunning...1stillrunning...1stillrunning...2stillrunning...2stillrunning...0stillrunning...1stillrunning...2stopthis有谁知道如何在不复制的

go - 多个goroutine的调度

packagemainimport"fmt"funcsquare(cchanint){fmt.Println("[square]reading(4)")num:=输出:[main]main()started(1)[main]senttestNumtosquareChan(2)[cube]reading(3)[square]reading(4)[square]calc(5)[main]resuming(6)[main]senttestNumtocubeChan(7)[main]resuming(8)[main]readingfromchannels(9)backfrom[square](

google-app-engine - 具有运行时 go111 url 调度问题的 dev_appserver.py

我仍在努力让我的旧式应用引擎至少在go111下工作(由于依赖于内存缓存,go112将无法工作)。我现在正在为我的静态文件的app.yaml配置问题绊倒,我之前使用了一个完全静态的目录布局,只是在根目录中指定了一些动态处理程序,如下所示:runtime:go111handlers:-url:/_ah/.*script:autologin:adminsecure:always-url:/dynamicscript:autosecure:always-url:/admin/.*script:autologin:adminsecure:always-url:(.*)/static_files:

concurrency - 潜在递归任务的工作池(即,每个作业都可以排队其他作业)

我正在编写一个应用程序,用户可以从多个“作业”(实际上是URL)开始。在开始(主例程)时,我将这些URL添加到队列中,然后启动x个处理这些URL的goroutines。在特殊情况下,URL指向的资源可能包含更多必须添加到队列中的URL。这3名worker正在等待新工作的到来并处理它们。问题是:一旦每个worker都在等待工作(并且没有人在生产),worker应该完全停止。因此,要么所有人都工作,要么没有人工作。我当前的实现看起来像这样,但我认为它并不优雅。不幸的是,我想不出一个不包含竞争条件的更好方法,而且我不完全确定这个实现是否真的按预期工作:varqueue//fromsomewh

sql - Go 相当于 GCD 串行调度队列

是否有与Apple的GCD串行调度队列等效的Go?到目前为止,我只找到了一种解决方案,即函数channel。work:=make(chanfunc())我会有一个函数从这个channel接收并调用接收到的函数。这些函数必须按FIFO顺序执行。在Go中是否有更好的方法或结构来执行此操作?这应该不会有什么不同,但我希望将SQL查询排队以为此在FIFO中运行。 最佳答案 @OneOfOne,很接近但不完全是。我最终在Go中实现了串行调度队列可用here.它基本上是一个go例程,阻塞在func()类型的channel上,并运行按顺序传递的函

go - Golang的组合继承如何将Commands调度到合适的CommandHandler?

我想学习用Go编程,我决定作为一个宠物程序,我会为几个CommandHandler做一个简单的不同命令的调度程序(如果CommandHandler与它应该处理的命令同名。)我的问题是,当我想要一个CommandHandlerManager来发布将被分派(dispatch)到正确的CommandHandler的命令时,它告诉我我需要有一个具体的HelloWorldCommand实现,因为HelloWorldCommandHandler没有实现Command的接口(interface).编译时的错误信息E:\Desktop\ManBear\golang\src>gorunmain.go#c

go - GoLang 中的 HouseRobber 编程任务中的错误

问题陈述相当简单:Givenalistofintegersreturnthemaximumsumofnonadjacentelements..例如houseRobber([5,0,0,5])=>10和houseRobber([2,1,2])=>4OnesolutionIdecidedonhas2parts:生成所有可行的索引列表(例如[5,0,0,5]=>[[0,2],[0,3],[1,3]])确定给定索引集的最大元素总和。(例如[5,0,0,5],[[0,2],[0,3],[1,3]]=>10)所以我开始实现我的解决方案。我已将脚本包设为主要包并包含一个我自己的失败测试,​​以便任何

c# - 来自 golang 和 c# 的 elixir 函数的并行或异步任务

我正在和Phoenix一起学习Elixir。我很容易地构建了一些RESTAPI服务器,但是我还需要实现一个要求。我需要能够执行并行或异步任务以从后端调用/执行某些API,并将这些结果放入JSON响应中。这就是我从Go和C#中大致实现它的方式//GolanguserCount:=make(chanint)usersList:=make(chan[]Users)gogetAggregateUserCounts(userCount)gogetGetUsersList(usersList)//dootherheavytasksfromherehttpJsonResponse(map[strin