no prio available (it's hard to manage.... a task queued 3 hours ago with prio 7 comes before of after one with prio 8 queued 2 hours ago ?).
"hackish way": tasks are picked up ordered by next_run_time. So, queue your tasks with next_runtime = request.now - datetime.timedelta(hours=1) kinda works. Right way: separate queues, "important tasks" and "less important tasks". You can create different queues assigning different group_name to tasks and start - at least 2 - separate scheduler processes. By default tasks are in the group 'main', and the scheduler worker processes those only def task1(a, b=2): #need high prio def task2(a, b=2): #needs low prio from gluon.scheduler import Scheduler mysched = Scheduler(db) #new api mysched.queue_task(task1, ['a'], {'b': 1}, group_name='fast_track') mysched.queue_task(task2, ['a'], {'b' : 1}, group_name='slow_track') #old api from gluon.serializers import json db.scheduler_task.validate_and_insert(function_name='task1', args=json(['a' ]), vars=json({'b':1}), group_name='fast_track') db.scheduler_task.validate_and_insert(function_name='task2', args=json(['a' ]), vars=json({'b':1}), group_name='slow_track') Then, start one scheduler per queue with web2py.py -K appname:fast_track,appname:slow_track If you just need some important tasks without assignign "slow_track" to the zillions you have already, just forget about the group_name='slow_track' and start schedulers with this command line web2py.py -K appname,appname:fast_track Then assign to fast_track only the ones you want to exec first and, assuming that fast_track has less tasks in queue, they will be executed before the zillion ones in the main group. Clear ? On Saturday, October 20, 2012 3:01:24 AM UTC+2, Adi wrote: > > Does work. Thank you both very much! > > Now that I have thousands of queued/backlogged tasks in a scheduler, I > noticed that my regular tasks, which are of higher priority will be on hold > until everything else gets processed. Maybe, it would be a good idea to > have a field for a priority of a task? (just a thought) > > On Fri, Oct 19, 2012 at 5:11 PM, Niphlod <nip...@gmail.com > <javascript:>>wrote: > >> it's missing the outer loop. >> >> _last_id = 0 >> _items_per_page=1000 >> while True: >> rows = db(db.table.id>_last_id).select(limitby=(0,_items_per_page), >> orderby=db.table.id) >> if len(rows) == 0: >> break >> for row in rows: >> >> #do something >> _last_id = row.id >> >> Should work. >> >> >> On Friday, October 19, 2012 10:52:06 PM UTC+2, Adi wrote: >> >>> i put it exactly as it is, but it stopped working after 1000 records... >>> will double check again. >>> >>> >>> On Fri, Oct 19, 2012 at 3:47 PM, Vasile Ermicioi <elf...@gmail.com>wrote: >>> >>>> _last_id = 0 >>>>> _items_per_page=1000 >>>>> for row in db(db.table.id>_last_id).selec**t(limitby=(0,_items_per_page), >>>>> orderby=db.table.id): >>>>> #do something >>>>> _last_id = row.id >>>> >>>> >>>> you don;t need to change anything to load all data, this code is >>>> loading everything in slices as you need, >>>> all records are ordered by id, and next query will load all next >>>> _items_per_page items >>>> db.table.id>_last_id - will skip all previous records >>>> >>>> -- >>>> >>>> >>>> >>>> >>> >>> >>> -- >> >> >> >> > > > > -- > > Thanks, > Adnan > > video: http://vimeo.com/24653283 > > > --