Mysql failed to start linux

Ошибка при запуск служба Mysql

Добрый день уважаемые программисты. Устанавливал Apache+php+Mysql чистом Ubuntu-16.04-amd64. Apache запускалось нормально без никаких проблем. Но при запуск служб mysql:

Оформите используя LORCODE www.linux.org.ru/help/lorcode.md (подсказка: используйте тег [code] выхлоп [/code])

Для длинных «портянок» используйте https://pastebin.com или аналогичный сервис, сюда прилагайте ссылку.

[ERROR] InnoDB: Cannot allocate memory for the buffer pool

Он же пишет что ему не хватает памяти

Он же пишет что ему не хватает памяти

У меня VDS: Дисковое пространство: 5 GB Процессор: 700 MHz Оперативная память: 256 Mb

Что посоветуйте. Значить не получается работать с этим сервером?

Все зависит от Ваших задач.
Если конечное приложение совсем не ресурсоемкое и большого потока клиентов не ожидается, то попробовать можно. Но нужно будет очень хорошо покрутить настройки у всего что есть в системе.
Вообще 256Мб RAM для одновременной работы apache и mysql выглядит странным решением..

Включите swap, если с ним будет работать (но будет тормозить и тупить) — увеличивайте RAM.

Источник

Не запускается Mysql

MySQL или MariaDB — это один из самых популярных движков баз данных, который используется для обеспечения работы большинства веб-сайтов в интернете, а также множества других проектов.

Иногда случается, что из-за после изменения настроек или по какой-либо другой причине mysql не запускается. Это довольно серьезная проблема, особенно, когда такая ситуация случается на сервере публичного проекта. В этой статье мы рассмотрим основные причины почему может возникать такая проблема, а также пути решения. В качестве примера будет использоваться Mariadb и Ubuntu.

Почему не запускается MySQL сервер?

Если вы используете systemd для запуска сервисов, то получите такую ошибку:

failed to start mysql server или job for mysql failed because the control proccess exited

Из сообщения понято только то что что-то пошло не так, но что именно неизвестно. Чаще всего проблемы в работе MySQL могут вызвать такие причины:

  • Синтаксические ошибки в конфигурационном файле;
  • Неверные настройки;
  • Недостаточное количество оперативной памяти на сервере;
  • Проблемы с правами доступа;
  • Сетевой порт уже занят;
  • Таблицы баз данных повреждены;

Дальше мы рассмотрим основные пути решения этих проблем. Но сначала нам нужно выяснить почему не запускается программа. Гадать на кофейной гуще и перебирать все возможные методы решения можно очень долго, самым эффективным решением будет посмотреть какие ошибки выдает сама программа.

Что делать если не запускается MySQL?

Первым делом, если вы меняли настройки в конфигурационном файле надо проверить его на ошибки. Встроенной утилиты для таких целей нет, но можно запустить mysql daemon с опцией —help:

/usr/sbin/mysqld —help —verbose

В начале вывода будут представлены обнаруженные в основном конфигурационном файле ошибки. Например, здесь я специально добавил несуществующую переменную. Вам остается только исправить ошибки и перезапустить mysql:

systemctl restart mariadb

Если же это не сработало и вы все еще получаете ошибку, посмотрите лог загрузки systemd для этого сервиса:

systemctl status -l mariadb

Иногда здесь тоже можно найти полезную информацию, но в данном случае ничего нет. Следующий шаг — просмотр лога mysql. Если лог еще не включен, включаем его добавив такую строчку в /etc/mysql/my.cnf в секцию [mysqld]:

sudo vi /etc/mysql/my.cnf

[mysqld]
log-error=/var/log/mysql/error.log
Затем снова пытаемся запустить сервис и смотрим на появившиеся в логе ошибки:

Читайте также:  What are regular expressions in linux

tail -f /var/log/mysql/error.log

Здесь вы увидите ошибки, которые мешают запустить mysql. Здесь надо искать слова: Fail, Error, Warning, Aborted и так далее. Вам остается только их исправить. Исправить проблемы с синтаксисом, убрать опции, которые потребляют слишком много памяти и исправить другие проблемы. А теперь рассмотрим несколько распространенных проблем.

1. Изменение размера буфера innodb

Если вы измените значение директивы innodb_buffer_pool_size в большую или меньшую сторону пока сервис работает, то перезапустить вы его уже не сможете. Перед тем как менять значение директивы остановите mysql:

sudo systemctl stop mariadb

Затем удалите старые логи innodb или просто их переименуйте:

sudo mv /var/lib/mysql/ib_logfile0 <,bak>
sudo mv /var/lib/mysql/ib_logfile1

И только после этого можете снова запускать сервис, он запустится с новыми настройками размера буфера. Только будьте аккуратны с выбором размера. При слишком большом размере может не хватить памяти для запуска, так как весь буфер хранится в ОЗУ.

sudo systemctl start mariadb

2. Ошибка Permission denied

MySQL хранит файлы базы данных на диске. У движка базы данных должен быть полный доступ к папке, в которой хранятся эти файлы. По умолчанию в Ubuntu это /var/lib/mysql/. Все файлы в этой папке должны принадлежать пользователю mysql:

ls -l /var/lib/mysql/

Если это не так, исправляем командой:

sudo chown -R mysql:mysql /var/lib/mysql/

3. Ошибка Address already in use

MySQL может использовать файловый сокет Linux или же сетевой сокет, тогда база данных будет доступна другим программам на порту 3306. Если сейчас уже запущен другой процесс mysql или какой-либо другой процесс занимает этот порт вы получите ошибку Address already in use. Чтобы ее решить смотрим какой процесс использует порт:

sudo ss -lptn ‘sport = :3306’

Например, здесь мы видим, что запущен другой экземпляр mysql с PID 11240. Вы можете его завершить с помощью kill:

sudo kill -TERM 11240

Теперь база данных запуститься.

4. Ошибка corrupt database page Mysql

Если mysql завершился некорректно из-за недостатка памяти или других проблем, например, проблем с файловой системой, то таблицы innodb могут быть повреждены — corrupt database page. Это происходит не так часто. При такой проблеме вы увидите такую запись в логе:

Проблема серьезная, но решаемая. В самом сообщении об ошибке система рекомендует сделать резервную копию таблиц, удалить их и создать заново из резервной копии. Но для этого должна быть запущена база данных, а она не запускается.

Нам необходимо запустить mysql в режиме восстановления, в котором все повреждения таблиц будут игнорироваться. Для этого добавляем в конфигурационный файл /etc/mariadb/my.cnf строку:

sudo vi /etc/mariadb/my.cnf

Затем запускаем mysql:

systemctl start mariadb

Ошибок не будет и сервис запуститься. Нам остается только исправить таблицы. Для этого можно воспользоваться инструментом mysqlcheck:

mysqlcheck -u root —auto-repair —all-databases

Готово. Теперь возвращаемся в конфигурационный файл и комментируем или удаляем строку innodb_force_recovery.

После этого можно перезапустить mysql и сервис будет работать в обычном режиме:

sudo systemctl restart mariadb

Выводы

В этой статье мы рассмотрели основные причины почему не запускается mysql сервер. Теперь вы сможете очень быстро с ними справиться, если столкнетесь в своей работе. А с какими еще проблемами кроме этих сталкивались вы? Какие были пути решения? Давайте дополним статью вместе, пишите в комментариях!

Источник

Помогите с MYSQL

Доброго времни суток. Помогите запустить MYSQL, когда я ввожу service mysql start, оно мне пишет: [FAIL] Starting MySQL database server: mysqld . . . . . . . . . . . . . . failed!

Логи мускула пустые а в логе запуска демонов выдает ето:

Oct 21 01:14:24 debian /etc/init.d/mysql[16895]: error: ‘Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)’

Читайте также:  Install windows files on mac

Oct 21 01:14:24 debian /etc/init.d/mysql[16895]: Check that mysqld is running and that the socket: ‘/var/run/mysqld/mysqld.sock’ exists!

в интернете много чего нашол но ниче не помогло так как файл mysqld.sock у меня отсутствует полностью find / -type s его не нашла, кстати у меня сечас стоит Дебиан 7.

Заранее благодарен за помощь.

как был установлен mysql?
вангую ошибки в конфиге

Установил такой командой: aptitude install mysql-server mysql-client

А у mysqld есть права на запись/чтение /var/run/mysqld/?

drwxr-xr-x 2 mysql root 40 Oct 21 00:39 mysqld

как насчет попробовать указать в конфигах другое местоположение файла? как здесь, например, http://stackoverflow.com/a/18808633 .

У меня нету етого файла вовсе.

Хм. В дебе такого обычно не бывает. Выкладывай куда-нибудь выводы следующих комман:

(можно без sudo’в если ты под root’ом)

sudo tail -66 /var/log/daemon.log после первых 2 команд:

Oct 21 02:00:20 debian mysqld_safe: Starting mysqld daemon with databases from /var/lib/mysql Oct 21 02:00:20 debian mysqld: 131021 2:00:20 [Note] Plugin ‘FEDERATED’ is disabled. Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: The InnoDB memory heap is disabled Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: Mutexes and rw_locks use GCC atomic builtins Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: Compressed tables use zlib 1.2.7 Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: Using Linux native AIO Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: Initializing buffer pool, size = 128.0M Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: Completed initialization of buffer pool Oct 21 02:00:20 debian mysqld: 131021 2:00:20 InnoDB: highest supported file format is Barracuda. Oct 21 02:00:21 debian mysqld: 131021 2:00:21 InnoDB: Waiting for the background threads to start Oct 21 02:00:22 debian mysqld: 131021 2:00:22 InnoDB: 5.5.31 started; log sequence number 1595675 Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [Note] Server hostname (bind-address): ‘localhost’; port: 3306 Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [Note] — ‘localhost’ resolves to ‘127.0.0.1’; Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [Note] — ‘localhost’ resolves to ‘::1’; Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [Note] Server socket created on IP: ‘127.0.0.1’. Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [ERROR] Can’t start server: Bind on TCP/IP port: Cannot assign requested address Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [ERROR] Do you already have another mysqld server running on port: 3306 ? Oct 21 02:00:22 debian mysqld: 131021 2:00:22 [ERROR] Aborting Oct 21 02:00:22 debian mysqld: Oct 21 02:00:22 debian mysqld: 131021 2:00:22 InnoDB: Starting shutdown. Oct 21 02:00:23 debian mysqld: 131021 2:00:23 InnoDB: Shutdown completed; log sequence number 1595675 Oct 21 02:00:23 debian mysqld: 131021 2:00:23 [Note] /usr/sbin/mysqld: Shutdown complete Oct 21 02:00:23 debian mysqld: Oct 21 02:00:23 debian mysqld_safe: mysqld from pid file /var/run/mysqld/mysqld.pid ended Oct 21 02:00:35 debian /etc/init.d/mysql[8070]: 0 processes alive and ‘/usr/bin/mysqladmin —defaults-file=/etc/mysql/debian.cnf ping’ resulted in Oct 21 02:00:35 debian /etc/init.d/mysql[8070]: #007/usr/bin/mysqladmin: connect to server at ‘localhost’ failed Oct 21 02:00:35 debian /etc/init.d/mysql[8070]: error: ‘Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)’ Oct 21 02:00:35 debian /etc/init.d/mysql[8070]: Check that mysqld is running and that the socket: ‘/var/run/mysqld/mysqld.sock’ exists! Oct 21 02:00:35 debian /etc/init.d/mysql[8070]:

# ls -la /run/mysqld/ total 0 drwxr-xr-x 2 mysql root 40 Oct 21 01:52 . drwxr-xr-x 16 root root 660 Oct 21 01:52 ..

# cat /etc/init.d/mysql #!/bin/bash # ### BEGIN INIT INFO # Provides: mysql # Required-Start: $remote_fs $syslog # Required-Stop: $remote_fs $syslog # Should-Start: $network $time # Should-Stop: $network $time # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Start and stop the mysql database server daemon # Description: Controls the main MySQL database server daemon «mysqld» # and its wrapper script «mysqld_safe». ### END INIT INFO # set -e set -u $

Читайте также:  Выходит сообщение активации windows

test -x /usr/bin/mysqld_safe || exit 0

SELF=$(cd $(dirname $0); pwd -P)/$(basename $0) CONF=/etc/mysql/my.cnf MYADMIN=«/usr/bin/mysqladmin —defaults-file=/etc/mysql/debian.cnf»

# priority can be overriden and «-s» adds output to stderr ERR_LOGGER=«logger -p daemon.err -t /etc/init.d/mysql -i»

# Safeguard (relative paths, core dumps..) cd / umask 077

# mysqladmin likes to read /root/.my.cnf. This is usually not what I want # as many admins e.g. only store a password without a username there and # so break my scripts. export HOME=/etc/mysql/

## Fetch a particular option from mysql’s invocation. # # Usage: void mysqld_get_param option mysqld_get_param() < /usr/sbin/mysqld --print-defaults \ | tr " " «\n» \ | grep — "--$1" \ | tail -n 1 \ | cut -d= -f2 >

# check for diskspace shortage datadir=`mysqld_get_param datadir` if LC_ALL=C BLOCKSIZE= df —portability $datadir/. | tail -n 1 | awk ‘< exit ($4>4096) >’; then log_failure_msg «$0: ERROR: The partition with $datadir is too full!» echo «ERROR: The partition with $datadir is too full!» | $ERR_LOGGER exit 1 fi >

## Checks if there is a server running and if so if it is accessible. # # check_alive insists on a pingable server # check_dead also fails if there is a lost mysqld in the process list # # Usage: boolean mysqld_status [check_alive|check_dead] [warn|nowarn] mysqld_status () < ping_output=`$MYADMIN ping 2>&1`; ping_alive=$(( ! $? ))

ps_alive=0 pidfile=`mysqld_get_param pid-file` if [ -f «$pidfile» ] && ps `cat $pidfile` >/dev/null 2>&1; then ps_alive=1; fi

if [ «$1» = «check_alive» -a $ping_alive = 1 ] || [ «$1» = «check_dead» -a $ping_alive = 0 -a $ps_alive = 0 ]; then return 0 # EXIT_SUCCESS else if [ «$2» = «warn» ]; then echo -e «$ps_alive processes alive and ‘$MYADMIN ping’ resulted in\n$ping_output\n» | $ERR_LOGGER -p daemon.debug fi return 1 # EXIT_FAILURE fi >

case «$<1:-">» in ‘start’) sanity_checks; # Start daemon log_daemon_msg «Starting MySQL database server» «mysqld» if mysqld_status check_alive nowarn; then log_progress_msg «already running» log_end_msg 0 else # Could be removed during boot test -e /var/run/mysqld || install -m 755 -o mysql -g root -d /var/run/mysqld

# Start MySQL! /usr/bin/mysqld_safe > /dev/null 2>&1 &

# 6s was reported in #352070 to be too few when using ndbcluster for i in 1 2 3 4 5 6 7 8 9 10 11 12 13 14; do sleep 1 if mysqld_status check_alive nowarn ; then break; fi log_progress_msg «.» done if mysqld_status check_alive warn; then log_end_msg 0 # Now start mysqlcheck or whatever the admin wants. output=$(/etc/mysql/debian-start) [ -n «$output» ] && log_action_msg «$output» else log_end_msg 1 log_failure_msg «Please take a look at the syslog» fi fi ;;

‘stop’) # * As a passwordless mysqladmin (e.g. via

/.my.cnf) must be possible # at least for cron, we can rely on it here, too. (although we have # to specify it explicit as e.g. sudo environments points to the normal # users home and not /root) log_daemon_msg «Stopping MySQL database server» «mysqld» if ! mysqld_status check_dead nowarn; then set +e shutdown_out=`$MYADMIN shutdown 2>&1`; r=$? set -e if [ «$r» -ne 0 ]; then log_end_msg 1 [ «$VERBOSE» != «no» ] && log_failure_msg «Error: $shutdown_out» log_daemon_msg «Killing MySQL database server by signal» «mysqld» killall -15 mysqld server_down= for i in 1 2 3 4 5 6 7 8 9 10; do sleep 1 if mysqld_status check_dead nowarn; then server_down=1; break; fi done if test -z «$server_down»; then killall -9 mysqld; fi fi fi

if ! mysqld_status check_dead warn; then log_end_msg 1 log_failure_msg «Please stop MySQL manually and read /usr/share/doc/mysql-server-5.5/README.Debian.gz!» exit -1 else log_end_msg 0 fi ;;

‘restart’) set +e; $SELF stop; set -e $SELF start ;;

‘reload’|’force-reload’) log_daemon_msg «Reloading MySQL database server» «mysqld» $MYADMIN reload log_end_msg 0 ;;

‘status’) if mysqld_status check_alive nowarn; then log_action_msg «$($MYADMIN version)» else log_action_msg «MySQL is stopped.» exit 3 fi ;;

*) echo «Usage: $SELF start|stop|restart|reload|force-reload|status» exit 1 ;; esac

Источник

Оцените статью