У меня есть скрипт Python, который запрашивает сервер MySQL на общем хосте Linux. По некоторым причинам, запросы к MySQL часто возвращают ошибку «сервер ушел»:
_mysql_exceptions.OperationalError: (2006, 'MySQL server has gone away')
Если вы попытаетесь выполнить запрос сразу же после этого, он обычно будет успешным. Итак, я хотел бы знать, есть ли в python разумный способ попытаться выполнить запрос, и, если он потерпит неудачу, повторить попытку с фиксированным числом попыток. Вероятно, я бы хотел, чтобы он попробовал 5 раз, прежде чем полностью отказаться.
Вот код, который у меня есть:
conn = MySQLdb.connect(host, user, password, database)
cursor = conn.cursor()
try:
cursor.execute(query)
rows = cursor.fetchall()
for row in rows:
# do something with the data
except MySQLdb.Error, e:
print "MySQL Error %d: %s" % (e.args[0], e.args[1])
Очевидно, что я мог бы сделать это, сделав еще одну попытку в предложении кроме, но это невероятно уродливо, и я чувствую, что должен быть достойный способ добиться этого.