2013-11-03 3 views
6

Ich versuche, eine Flask-App mit Heroku zu implementieren. Es ist eine einfache API. Funktioniert gut lokal mit Vorarbeiter, aber ich bekomme Fehler (Protokoll ist unten), wenn auf Heroku gestartet wird.Flask-App nicht starten auf Heroku-Server

Dies ist meine App-Code (ich weiß, es ist aber in einem Block suchen, aber ich habe Probleme, die es zu Dateien aufgeteilt):

import flask 
import flask.ext.sqlalchemy 
import flask.ext.restless 

app = flask.Flask(__name__) 
app.config['DEBUG'] = True 
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://user:[email protected]/db' 
db = flask.ext.sqlalchemy.SQLAlchemy(app) 


from sqlalchemy import Column, Integer, String, ForeignKey,\ 
    Date, DateTime, Boolean, Float 


class fruits(db.Model): 
    __tablename__ = 'fruits' 
    id = Column(Integer, primary_key=True) 
    name = Column(String(50),nullable=False) 
    calories = Column(Integer, nullable=False) 
    amount = Column(Integer, nullable=False) 
    unit = Column(String(10),nullable=False) 
    url = Column(String(100),nullable=True) 


@app.route('/') 
def hello_world(): 
    return 'Hello World!' 


# Create the database tables. 
db.create_all() 

# Create the Flask-Restless API manager. 
manager = flask.ext.restless.APIManager(app, flask_sqlalchemy_db=db) 

# Create API endpoints, which will be available at /api/<tablename> by 
# default. Allowed HTTP methods can be specified as well. 
manager.create_api(fruits, methods=['GET', 'POST', 'DELETE']) 
manager.create_api(tmp, methods=['GET', 'POST', 'DELETE']) 


# start the flask loop 

if __name__ == '__main__': 
     import os 
     port = int(os.environ.get('PORT', 33507)) 
     app.run(host='0.0.0.0', port=port) 

Dies wird Heroku log:

at=error code=H14 desc="No web processes running" method=GET path=/ host=blooming-taiga-1210.herokuapp.com fwd="188.33.19.82" dyno= connect= service= status=503 bytes= 

und mein procfile:

web: python __init__.py 
+0

Verwenden Sie externen MySQL-Server? – zero323

Antwort

18

gibt es eigentlich eine laufende dyno web genannt? Es sieht aus wie Sie scale your web dyno vergessen haben könnten:

wie dieser einen Eintrag hinzufügen in Ihrem procfile:

heroku ps:scale web=1 

Sie

heroku ps 

verwenden können, um zu bestätigen, dass Ihr web Dyno läuft.

+1

Es funktioniert, wenn ich es in der Konsole mache, nein in Procfile. Danke! –

+0

Ich kann nicht upbooten. Um weniger Ruf;) –

+0

Heilige Hölle, ich kann nicht glauben, dass das nicht in ihren Bereitstellungsdokumenten irgendwo ist. – Chris