У меня Ubuntu 10.04 LTS установлен на машине в качестве сервера LAMP. Время от времени мое соединение с MySQL прерывается, и я получаю следующее сообщение об ошибке:
Warning: mysql_connect(): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (111)
После этого мне нужно перезагрузить сервер, чтобы он снова заработал.
Кажется, это произошло без предупреждения. Как лучше всего решить эту проблему? Я новичок в командной строке Linux, поэтому будьте осторожны.
Редактировать: Посмотрев на журнал mysql, я обнаружил следующее:
100813 18:56:16 [Note] Plugin 'FEDERATED' is disabled.
100813 18:56:16 InnoDB: Started; log sequence number 0 44233
100813 18:56:16 [ERROR] Column count of mysql.db is wrong. Expected 22, found 20. The table is probably corrupted
100813 18:56:16 [ERROR] mysql.user has no `Event_priv` column at position 29
100813 18:56:16 [ERROR] Event Scheduler: An error occurred when initializing system tables. Disabling the Event Scheduler.
100813 18:56:16 [Note] /usr/sbin/mysqld: ready for connections.
Version: '5.1.41-3ubuntu12' socket: '/var/run/mysqld/mysqld.sock' port: 3306 (Ubuntu)
100813 18:56:17 - mysqld got signal 11 ;
This could be because you hit a bug. It is also possible that this binary
or one of the libraries it was linked against is corrupt, improperly built,
or misconfigured. This error can also be caused by malfunctioning hardware.
We will try our best to scrape up some info that will hopefully help diagnose
the problem, but since we have already crashed, something is definitely wrong
and this may fail.
похоже, что ваш сервер mysql разрушает и удаляет сокет, посмотрите журналы сервера mysql, он должен указать, в чем проблема.
РЕДАКТИРОВАТЬ:
Хорошо, это показывает, что ваша таблица пользователей повреждена, попробуйте восстановить ее
mysql
use mysql
repair table user