Of course. This is what I have in a test application: Models ====== db.py
if not request.env.web2py_runtime_gae: # used tunnel *db_s = DAL('mysql://crm:password@localhost:3307/CRM',migrate_enabled= False, fake_migrate_all=True)* else: ## connect to Google BigTable (optional 'google:datastore://namespace') db_s = DAL('google:datastore') ## store sessions and tickets there session.connect(request, response, db_s = db_s) db_scheduler.py # coding: utf8 from scheduler import Scheduler import datetime import urllib, urllib2 from urlparse import urlparse import unicodedata def send_msg(): email_sent=mail.send(to='t...@email.com', subject='email_subject', message='message') print 'sent' return myscheduler = Scheduler(db_s, dict(send_msg=send_msg)) Controllers =========== test.py def test(): db_s.scheduler_task.insert( status='QUEUED', application_name='test2', task_name='send test abandoned email', function_name='send_msg', enabled=True, start_time = request.now, next_run_time = request.now+datetime.timedelta( minutes=2), stop_time = request.now+datetime.timedelta(days =1), repeats = 1, # run 1 times period = 120, # every 2m timeout = 60, # should take less than 60 seconds ) Scheduler started: $ python web2py.py -a pass -K test2 -X > log_scheduler.log On Friday, October 5, 2012 5:58:37 PM UTC-4, Massimo Di Pierro wrote: > > Can you share some code so we ret reproduce it and fix it? We do not need > all the code. Just a minimalist example that causes the same problem. > > On Friday, 5 October 2012 16:24:11 UTC-5, Adi wrote: >> >> yes, i just confirmed by running in parallel 9/13 and 10/5 >> >> results: >> 9/13 partially works (will execute task, mark it as "COMPLETED" in >> scheduler_tasks, but will mark it as "FAILED" in scheduler_run and won't >> update details in there... >> 10/5 doesn't work (RuntimeError: Cannot duplicate a Singleton) >> >> >> On Fri, Oct 5, 2012 at 11:59 AM, Massimo Di Pierro <massimo....@gmail.com >> > wrote: >> >>> To summarize: >>> 1) 9/13 version works >>> 2) 10/4 version does not work as you expected >>> >>> Did you try any 10/5 version? >>> >>> >>> On Friday, 5 October 2012 10:21:46 UTC-5, Adi wrote: >>>> >>>> >>>> for what it's worth, just want to let you know that after rolling back >>>> to "Version 2.0.9 (2012-09-13 23:51:30) stable" tasks are getting >>>> executed, marked as COMPLETED, but schedule_run is being marked as FAILED >>>> w >>>> bellow specified sys.exit(1). >>>> >>>> anyway... this is perfect for now, and customers won't suffer :) >>>> >>>> scheduler and workflow are two crucial things in complex applications >>>> from my prospective, so big thanks for scheduler, and can't wait to start >>>> testing workflow once it's in. >>>> >>>> On Friday, October 5, 2012 9:27:22 AM UTC-4, Adi wrote: >>>>> >>>>> >>>>> Created a new application from admin panel, accessing single mysql db, >>>>> inserted one task that sends an email and prints a test message. >>>>> >>>>> Version 2.0.9 (2012-10-04 20:17:03) dev >>>>> >>>>> def test(): >>>>> db.scheduler_task.insert( >>>>> status='QUEUED', >>>>> application_name='test2', >>>>> task_name='send reminder email', >>>>> function_name='send_msg', >>>>> enabled=True, >>>>> start_time = request.now, >>>>> next_run_time = request.now+datetime. >>>>> timedelta**(minutes=2), >>>>> stop_time = request.now+datetime. >>>>> timedelta**(days=1), >>>>> repeats = 1, # run 1 times >>>>> period = 120, >>>>> timeout = 60, # should take less than 60 >>>>> seconds >>>>> ) >>>>> >>>>> >>>>> >>>>> *started scheduler: * >>>>> asm21:web2py209 adnan$ python web2py.py -a pass -K test2 -X >>>>> web2py Web Framework >>>>> Created by Massimo Di Pierro, Copyright 2007-2012 >>>>> Version 2.0.9 (2012-10-04 20:17:03) dev >>>>> Database drivers available: SQLite(sqlite3), MySQL(pymysql), >>>>> PostgreSQL(pg8000), IMAP(imaplib) >>>>> please visit: >>>>> starting scheduler for "test2"... http://127.0.0.1:8000 >>>>> >>>>> use "kill -SIGTERM 831" to shutdown the web2py server >>>>> Currently running 1 scheduler processes >>>>> Processes started >>>>> ERROR:Rocket.Errors.Port8000:**Socket 127.0.0.1:8000 in use by other >>>>> process and it won't share. >>>>> WARNING:Rocket.Errors.**Port8000:Listener started when not ready. >>>>> Traceback (most recent call last): >>>>> File "/Users/adnan/web2py209/gluon/**restricted.py", line 209, in >>>>> restricted >>>>> exec ccode in environment >>>>> File "applications/test2/models/db.**py", line 15, in <module> >>>>> db = >>>>> DAL('mysql://crm:password@**localhost:3307/CRM',migrate_**enabled=False, >>>>> fake_migrate_all=True) >>>>> File "/Users/adnan/web2py209/gluon/**dal.py", line 6600, in __new__ >>>>> raise RuntimeError, 'Cannot duplicate a Singleton' >>>>> RuntimeError: Cannot duplicate a Singleton >>>>> >>>>> >>>>> *traceback error in the scheduler_run table after task was run (first >>>>> time):* >>>>> Traceback (most recent call last): >>>>> File "/opt/web-apps/web2py/gluon/**scheduler.py", line 203, in >>>>> executor >>>>> _env = env(a=a,c=c,import_models=**True) >>>>> File "/opt/web-apps/web2py/gluon/**shell.py", line 127, in env >>>>> environment = build_environment(request, response, session) >>>>> File "/opt/web-apps/web2py/gluon/**compileapp.py", line 388, in >>>>> build_environment >>>>> t = environment['T'] = translator(request) >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 437, in >>>>> __init__ >>>>> self.set_current_languages() >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 492, in >>>>> set_current_languages >>>>> pl_info = self.get_possible_languages_**info('default') >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 471, in >>>>> get_possible_languages_info >>>>> info = read_possible_languages(self.**folder) >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 250, in >>>>> read_possible_languages >>>>> lambda: read_possible_languages_aux(**langdir)) >>>>> File "/opt/web-apps/web2py/gluon/**cfs.py", line 40, in getcfs >>>>> return filter() if callable(filter) else '' >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 250, in >>>>> <lambda> >>>>> lambda: read_possible_languages_aux(**langdir)) >>>>> File "/opt/web-apps/web2py/gluon/**languages.py", line 215, in >>>>> read_possible_languages_aux >>>>> flist = oslistdir(langdir) >>>>> OSError: [Errno 2] No such file or directory: >>>>> 'applications/test2/languages' >>>>> >>>>> *traceback error in the scheduler_run table after task was run >>>>> (second time):* >>>>> Traceback (most recent call last): >>>>> File "/Users/adnan/web2py209/gluon/**scheduler.py", line 203, in >>>>> executor >>>>> _env = env(a=a,c=c,import_models=**True) >>>>> File "/Users/adnan/web2py209/gluon/**shell.py", line 134, in env >>>>> sys.exit(1) >>>>> SystemExit: 1 >>>>> >>>>> Please let me know if there is anything else I can test to help figure >>>>> out where exactly is the problem? It's a bit urgent for me to figure this >>>>> out, or I have to roll back production before weekend starts :( >>>>> >>>>> >>>>> >>>>> On Friday, October 5, 2012 12:00:57 AM UTC-4, Adi wrote: >>>>>> >>>>>> Will run more tests in the morning on a brand new application, since >>>>>> I can't see anything wrong (connection string duplication) in code right >>>>>> now. Unfortunately, can't roll back this functionality now, so will have >>>>>> to >>>>>> figure it out quickly. Thanks for help Massimo and Niphlod. >>>>>> >>>>>> >>>>>> On Thu, Oct 4, 2012 at 10:32 PM, Massimo Di Pierro wrote: >>>>>> >>>>>>> No. this should not be a problem. This is only be a problem if any >>>>>>> two have the same connection string. >>>>>>> >>>>>>> >>>>>>> On Thursday, 4 October 2012 21:10:58 UTC-5, Adi wrote: >>>>>>> >>>>>>>> I'm using 6 connections at the same time, 3 go to different >>>>>>>> databases on the same server, and 3 to totally different servers. Each >>>>>>>> connection has a different name >>>>>>>> >>>>>>>> db = DAL('mysql://crm:password@**loca**lhost:3307/CRM',migrate_** >>>>>>>> enable**d=True) >>>>>>>> db_us = DAL('mysql://web_US:password@**l**ocalhost:3307/DataUS',** >>>>>>>> migrate_**enabled=False, fake_migrate_all=True) >>>>>>>> db_ca = DAL('mysql://web_CA:password@**l**ocalhost:3307/DataCA', >>>>>>>> migrate_enabled=False, fake_migrate_all=True) >>>>>>>> ... >>>>>>>> >>>>>>>> Could something like this be a problem: >>>>>>>> In a scheduler function, based on application that inserted a task, >>>>>>>> I assign relevant connection to another object to use? >>>>>>>> >>>>>>>> if application='ca': >>>>>>>> db_front_end = db_ca >>>>>>>> elif application='us': >>>>>>>> db_front_end = db_us >>>>>>>> >>>>>>>> use db_front_end to retrieve data and perform scheduled task >>>>>>>> >>>>>>>> >>>>>>>> On Thu, Oct 4, 2012 at 9:42 PM, Massimo Di Pierro < >>>>>>>> massimo....@gmail.com> wrote: >>>>>>>> >>>>>>>>> This error can arise in two cases: >>>>>>>>> - you are using an a recent trunk version (not the latest) which >>>>>>>>> has a bug >>>>>>>>> - you are using the latest trunk (no bug) but you have a >>>>>>>>> duplicated connection in your code: >>>>>>>>> >>>>>>>>> db = DAL(....) >>>>>>>>> db = DAL(....) >>>>>>>>> >>>>>>>>> perhaps in different model files. Previous web2py did not check >>>>>>>>> and allowed you to have two connections to the same database. We >>>>>>>>> found this >>>>>>>>> is often source or errors. The new web2py checks and does not allow >>>>>>>>> you to >>>>>>>>> do it. Your would get the error you see. >>>>>>>>> >>>>>>>>> >>>>>>>>> On Thursday, 4 October 2012 14:42:59 UTC-5, Adi wrote: >>>>>>>>> >>>>>>>>>> We promoted latest night build to production, and scheduler >>>>>>>>>> started failing. At the same time there were some code changes, so >>>>>>>>>> I'm >>>>>>>>>> having a hard time tracing the source of the problem. >>>>>>>>>> >>>>>>>>>> Any insights while I'm trying to figure it out? >>>>>>>>>> >>>>>>>>>> Thanks, >>>>>>>>>> Adi >>>>>>>>>> >>>>>>>>>> db: mysql >>>>>>>>>> redhat linux >>>>>>>>>> w2p: Version 2.0.9 (2012-10-02 03:55:58) dev >>>>>>>>>> >>>>>>>>>> scheduler_run table: traceback field: >>>>>>>>>> Traceback (most recent call last): >>>>>>>>>> File "/opt/web-apps/web2py/gluon/**sc****heduler.py", line >>>>>>>>>> 203, in executor >>>>>>>>>> _env = env(a=a,c=c,import_models=**True****) >>>>>>>>>> File "/opt/web-apps/web2py/gluon/**sh****ell.py", line 134, in >>>>>>>>>> env >>>>>>>>>> sys.exit(1) >>>>>>>>>> SystemExit: 1 >>>>>>>>>> >>>>>>>>>> >>>>>>>>>> scheduler log: >>>>>>>>>> /opt/web-apps/web2py/gluon/**dal****.py:6597: >>>>>>>>>> DeprecationWarning: object.__new__() takes no parameters >>>>>>>>>> db = super(DAL, cls).__new__(cls, uri, *args, **kwargs) >>>>>>>>>> web2py Web Framework >>>>>>>>>> Created by Massimo Di Pierro, Copyright 2007-2012 >>>>>>>>>> Version 2.0.9 (2012-10-02 03:55:58) dev >>>>>>>>>> Database drivers available: SQLite(sqlite3), MySQL(pymysql), >>>>>>>>>> PostgreSQL(pg8000), IMAP(imaplib) >>>>>>>>>> starting single-scheduler for "crm"... >>>>>>>>>> Traceback (most recent call last): >>>>>>>>>> File "/opt/web-apps/web2py/gluon/**re****stricted.py", line >>>>>>>>>> 209, in restricted >>>>>>>>>> exec ccode in environment >>>>>>>>>> File "applications/crm/models/db.**py****", line 47, in >>>>>>>>>> <module> >>>>>>>>>> db = DAL('mysql://crm:password@**loca**** >>>>>>>>>> lhost:3307/CRM',migrate_**enable****d=False, >>>>>>>>>> fake_migrate_all=True) >>>>>>>>>> File "/opt/web-apps/web2py/gluon/**da****l.py", line 6595, in >>>>>>>>>> __new__ >>>>>>>>>> raise RuntimeError, 'Cannot duplicate a Singleton' >>>>>>>>>> RuntimeError: Cannot duplicate a Singleton >>>>>>>>>> >>>>>>>>>> -- >>>>>>>>> >>>>>>>>> >>>>>>>>> >>>>>>>>> >>>>>>>> >>>>>>>> >>>>>>>> -- >>>>>>> >>>>>>> >>>>>>> >>>>>>> >>>>>> >>>>>> >>>>>> >>>>>> -- >>> >>> >>> >>> >> >> >> >> -- >> >> Thanks, >> Adnan >> >> video: http://vimeo.com/24653283 >> >> >> --