RQ - ImportError:没有名为XXX的模块

时间:2018-03-26 15:45:00

标签: python flask redis backgroundworker apscheduler

我遇到了rq工作者的问题。

这是我的应用程序的结构:

app/
    run.py
    project/
        __init__.py
        clock.py
        views.py
        worker.py
        controllers/
           __init__.py
           leads_fb.py
运行我的应用程序后执行

时钟,这是代码:

from apscheduler.schedulers.background import BackgroundScheduler
from rq import Queue, get_current_job
from rq.job import Job 
from worker import conn
from controllers import leads_fb
import logging
import os


q = Queue(connection=conn)
sched = BackgroundScheduler()

def enque_jobs():
    info = '1aooEOTBQz1pAW915-JonL3Jh2mhclR5EZTHGotFBe7s||blah blah blah'
    job = q.enqueue(leads_fb.prueba, info)  
    print 'This job is run every 3 seconds.'

if os.environ.get("WERKZEUG_RUN_MAIN") == "true":
    sched.add_job(enque_jobs, 'interval', seconds=3)
    sched.start()

log = logging.getLogger('apscheduler.executors.default')
# log.setLevel(logging.INFO)  # DEBUG

# fmt = logging.Formatter('%(levelname)s:%(name)s:%(message)s')
h = logging.StreamHandler()
# h.setFormatter(fmt)
log.addHandler(h)
then clock enqueues jobs with the rq worker which is worker.py:

import os

import redis
from rq import Worker, Queue, Connection

listen = ['high', 'default', 'low']

redis_url = os.getenv('REDISTOGO_URL', 'redis://localhost:6379')

conn = redis.from_url(redis_url)

if __name__ == '__main__':
    with Connection(conn):
        worker = Worker(map(Queue, listen))
        worker.work()

并且执行排队作业的功能是controllers / leads_fb.py:

from wksh import init_wksh, get_last_row, write_in_cell

def prueba(info):
    print 'aaaaa'
    info = info.split('||')
    id_client = info[0]
    str_prueba = info[1]
    wksh = init_wksh(id_client)
    print wksh
    row = get_last_row(wksh)

    write_in_cell(wksh,'A'+str(row),str_prueba)
    print 'funciona  ' + str(row)

当我使用根目录中的run.py文件运行我的应用程序时,它给出了错误:ImportError:没有名为project.controllers.leads_fb的模块

我的run.py文件包含以下代码:

from project import app
from project import worker
from project import clock

if __name__ == "__main__":
    app.run(debug=True,host='127.0.0.1', port=1234)

我的app / project / init.py文件有这个

from flask import Flask

app = Flask(__name__)
app.config.from_object('config')

from . import views
from . import worker
from . import clock

请帮忙!!我已经坚持了一个星期,并且无法解决这个问题。我已经阅读了其他线程问题,并且已经明白它必须对PYTHONPATH做一些事情,将我的模块目录指向我的rq worker但我不知道如何实现它。

如何将导入路径添加到worker.py文件中?我已经测试了,如果我使用命令行' rqworker'在根目录中启动worker。它工作正常。我的应用程序认为worker.py文件位于根目录中,但它实际上位于根目录中的project /内。我如何以及在何处指定它以使其在本地工作并在Heroku中部署?

1 个答案:

答案 0 :(得分:0)

这是你的错误信息吗? " ImportError:没有名为config"

的模块

你错过了一行

的config.py.
app.config.from_object('config')

from_object(obj): obj可能是

  1. 将导入具有该名称的对象
  2. 实际对象引用:该对象直接使用
  3. 所以,为了使'配置'#39;有效,你可以在/ app

    下创建一个config.py.