Вопрос по mod-wsgi, bottle, python, apache, mysql – Ошибка 2006: «Сервер MySQL ушел» с использованием Python, Bottle Microframework и Apache

4

После доступа к моему веб-приложению с помощью:
 - Python 2.7
 - Бутылка микро рамки v. 0.10.6
 - Apache 2.2.22
 - mod_wsgi
 - на Ubuntu Server 12.04 64bit; Я получаю эту ошибку через несколько часов:

OperationalError: (2006, 'MySQL server has gone away')

Я использую MySQL - встроенный в Python. Обычно это происходит, когда я не обращаюсь к серверу. Я пытался закрыть все соединения, которые я делаю, используя это:

cursor.close()
db.close()

где db - это стандартный вызов MySQLdb.Connection ().

Файл my.cnf выглядит примерно так:

key_buffer      = 16M
max_allowed_packet  = 128M
thread_stack        = 192K
thread_cache_size       = 8
# This replaces the startup script and checks MyISAM tables if needed
# the first time they are touched
myisam-recover         = BACKUP
#max_connections        = 100
#table_cache            = 64
#thread_concurrency     = 10

Это файл конфигурации по умолчанию, за исключением max_allowed_packet 128M вместо 16M.

Запросы к базе данных довольно просты, самое большее, они получают приблизительно 100 записей.

Может кто-нибудь помочь мне исправить это? У меня была идея использовать try / кроме, но я не уверен, что это действительно сработает.

Заранее спасибо,

Джейми

Обновление: попытка / исключение вызовов не работает.

Проверьте это:stackoverflow.com/questions/207981/… Jakub M.

Ваш Ответ

3   ответа
0

https://stackoverflow.com/a/982873/209532

Он напрямую связан с драйвером MySQLdb (MySQL-python (не поддерживается) и mysqlclient (поддерживается ветвь)), но подход аналогичен для другого драйвера, который не поддерживает автоматическое повторное подключение.

-3

MySQLdb.connect("127.0.0.1","root","","db" )

вместо

MySQLdb.connect("localhost","root","","db" )

а потом

df.to_sql('df',sql_cnxn,flavor='mysql',if_exists='replace', chunksize=100)
23

Список возможных причин и возможных решений здесь:Справочное руководство по MySQL 5.5: C.5.2.9. Сервер MySQL ушел.

Возможные причины включают в себя:

You tried to run a query after closing the connection to the server. This indicates a logic error in the application that should be corrected. A client application running on a different host does not have the necessary privileges to connect to the MySQL server from that host. You have encountered a timeout on the server side and the automatic reconnection in the client is disabled (the reconnect flag in the MYSQL structure is equal to 0). You can also get these errors if you send a query to the server that is incorrect or too large. If mysqld receives a packet that is too large or out of order, it assumes that something has gone wrong with the client and closes the connection. If you need big queries (for example, if you are working with big BLOB columns), you can increase the query limit by setting the server's max_allowed_packet variable, which has a default value of 1MB. You may also need to increase the maximum packet size on the client end. More information on setting the packet size is given in Section C.5.2.10, “Packet too large”. You also get a lost connection if you are sending a packet 16MB or larger if your client is older than 4.0.8 and your server is 4.0.8 and above, or the other way around. and so on...

Другими словами, существует множество возможных причин. Просмотрите этот список и проверьте все возможные причины.

@ Тедек Ваш ответ мне очень поможет и сэкономит как минимум 1 день моего времени. Огромное спасибо .
@ Джейми: Пожалуйста. Я счастлив, что помог :)
Хорошо, автоматическое переподключение сработало. Спасибо за вашу помощь, это было легко! Jamie
На самом деле решение не сработало. После того, как я покинул приложение в течение примерно 24 часов, по-прежнему возникает ошибка. Я думаю, что новый вопрос будет, как мне создать автоматическое переподключение с использованием Python? Jamie
Спасибо за быстрый ответ. Я прочитал этот документ безрезультатно, большая часть его не применима. Единственное, о чем я мог подумать, это часть автоматического переподключения, которая восходит к моей попытке / кроме идеи. Если нет другого способа автоматического переподключения с использованием Python Jamie

Похожие вопросы