Как исправить ошибку Gets на сервере, которая вызывает проблемы с отображением? - PullRequest
0 голосов
/ 05 июня 2019

Список в левом столбце ontariocourts311.ca вместе с телом страницы под изображением периодически не отображается (что «исправлено» путем обновления страницы). Я нуб, и безуспешно пробовал разные версии оператора return.

Ошибка:

2019-06-05 16:39:26,765: Exception on / [GET]
Traceback (most recent call last):
  File "flask/app.py", line 2311, in wsgi_app
    response = self.full_dispatch_request()
  File "flask/app.py", line 1834, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "flask/app.py", line 1737, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "flask/_compat.py", line 36, in reraise
    raise value
  File "flask/app.py", line 1832, in full_dispatch_request
    rv = self.dispatch_request()
  File "flask/app.py", line 1818, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/home/mlesage/mysite/Court/application.py", line 40, in home
    complaints = db.execute("SELECT User_Complaint, Date, Review_Title FROM Posts")
  File "cs50/sql.py", line 224, in execute
    raise e
RuntimeError: (MySQLdb._exceptions.OperationalError) (2013, 'Lost connection to MySQL server during query')
[SQL: SELECT User_Complaint, Date, Review_Title FROM Posts]
(Background on this error at: http://sqlalche.me/e/e3q8)

from cs50 import SQL
from helpers import contacts # (a list of people stored in helpers)

# Configure db to mySQL database
db = SQL("mysql://user.mysql.pythonanywhere-services.com:3306/user$User_Reviews")
#timeout = db.execute(con.query('SET GLOBAL connect_timeout=6000'))

@app.route("/", methods=["GET", "POST"])
def home():
    reviews = [list of reviews, pulled from db, for display on page] 

    if request.method == "POST": 

        if User_Complaint != None:
            return redirect ('/')
            #return redirect(url_for('home', reviews = reviews, contacts = contacts))
        else:
            return render_template("home.html", reviews = reviews, contacts = contacts)

    # GETS METHOD
    else: 
        return render_template("home.html", reviews = reviews, contacts = contacts)   

Элементы страницы должны отображаться последовательно (т.е. список людей слева, отзывы в центре страницы и текстовое поле), независимо от того, используется ли метод GETS или POST.

1 Ответ

0 голосов
/ 06 июня 2019

Похоже, что проблема была связана с тем, что MySQL не имел доступных открытых соединений, которые, по-видимому, были исправлены с помощью небольшого изменения следующей строки:

db = SQL ("mysql: // user: password.mysql.pythonanywhere-services.com: 3306 / user $ User_Reviews ", pool_recycle = 280)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...