як перевстановити mysql?


38

Оновлення програмного забезпечення, серед іншого, зламало mysql, і я не зміг його відновити.

Підозріла причина: у мене був майже повний завантажувальний диск; оновлення заповнило диск перед його завершенням і тим самим залишило все в безладі. Я надав системі більше диска і перемістив / var на власний розділ. Я досі безуспішно намагаюся відновити mysql.

Нижче наведено те, що я намагався поки що (все як root). По-перше, mysql не запускається (443). Спроби виправити (444, 445) провалюються. Спроби видалити mysql та (?) Apparmor провалюються (446, 7, 8). Ефективніша спроба видалити mysql здається успішною (449), а попередні помилки вже не спостерігаються (450, 1, 2). Mysql не можна переналаштувати, оскільки його вже немає (453), але намагаючись перевстановити, він повертає старі повідомлення про помилки, і ми повертаємося до квадратного (454).

Я також перевірив це питання (хоча в моєму випадку воно не зламалось через оновлення до 12.04: воно вже працювало 12.10). Виправлення зламаного пакета myslq-сервера після оновлення до 12.04 і спробував там пропозиції (458, 461, 462) безрезультатно.

Що ще мені робити?

Це в 3.5.0-25-generic # 39-Ubuntu SMP пн 25 лютого 18:26:58 UTC 2013 x86_64 x86_64 x86_64 GNU / Linux

    443  service mysql start
         start: Job failed to start

    444  dpkg-reconfigure mysql-server-5.5
         /usr/sbin/dpkg-reconfigure: mysql-server-5.5
         is broken or not fully installed

    445  apt-get -f install
         ...
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         dpkg: dependency problems prevent configuration of
         mysql-server:
         mysql-server depends on mysql-server-5.5; however:
         Package mysql-server-5.5 is not configured yet.
         dpkg: error processing mysql-server (--configure):
         dependency problems - leaving unconfigured
         No apport report written because the error message
         indicates its a followup error from a previous failure.
         Errors were encountered while processing:
           mysql-server-5.5
           mysql-server
         E: Sub-process /usr/bin/dpkg returned an error code (1)

    446  apt-get remove mysql-server
         ...
         Removing mysql-server ...
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         No apport report written because MaxReports is reached already
         Errors were encountered while processing:
           mysql-server-5.5
         E: Sub-process /usr/bin/dpkg returned an error code (1)


    447  apt-get remove apparmor
         ...
         Package 'apparmor' is not installed, so not removed
         0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
         1 not fully installed or removed.
         After this operation, 0 B of additional disk space will be used. 
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         Errors were encountered while processing:
           mysql-server-5.5
         E: Sub-process /usr/bin/dpkg returned an error code (1)


    448  apt-get remove mysql-server
         Reading package lists... Done
         Building dependency tree       
         Reading state information... Done
         Package 'mysql-server' is not installed, so not removed
         0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
         1 not fully installed or removed.
         After this operation, 0 B of additional disk space will be used.
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         Errors were encountered while processing:
           mysql-server-5.5
         E: Sub-process /usr/bin/dpkg returned an error code (1)

    449  dpkg -r mysql-server-5.5
         (Reading database ... 322156 files and directories
         currently installed.)
         Removing mysql-server-5.5 ...
         Processing triggers for man-db ...
         Processing triggers for ureadahead ...

    450  apt-get remove mysql-server
         Reading package lists... Done
         Building dependency tree        
         Reading state information... Done
         Package 'mysql-server' is not installed, so not removed
         0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.

    451  apt-get remove apparmor
         Reading package lists... Done
         Building dependency tree       
         Reading state information... Done
         Package 'apparmor' is not installed, so not removed
         0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.

    452  apt-get -f install
         Reading package lists... Done
         Building dependency tree       
         Reading state information... Done
         0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.

    453  dpkg-reconfigure mysql-server-5.5
         /usr/sbin/dpkg-reconfigure: mysql-server-5.5 is broken
         or not fully installed

    454  apt-get install mysql-server
         Reading package lists... Done
         Building dependency tree       
         Reading state information... Done
         The following extra packages will be installed:
           mysql-server-5.5
         Suggested packages:
           tinyca mailx
         The following NEW packages will be installed:
           mysql-server mysql-server-5.5
         0 upgraded, 2 newly installed, 0 to remove and 0 not upgraded.
         Need to get 0 B/8,851 kB of archives.
         After this operation, 32.8 MB of additional disk space
         will be used.
         Do you want to continue [Y/n]? 
         Preconfiguring packages ...
         Selecting previously unselected package mysql-server-5.5.
         (Reading database ... 322081 files and directories
         currently installed.)
         Unpacking mysql-server-5.5 (from 
         .../mysql-server-5.5_5.5.29-0ubuntu0.12.10.1_amd64.deb) ...
         Selecting previously unselected package mysql-server.
         Unpacking mysql-server (from 
         .../mysql-server_5.5.29-0ubuntu0.12.10.1_all.deb) ...
         Processing triggers for ureadahead ...
         Processing triggers for man-db ...
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         dpkg: dependency problems prevent configuration of mysql-server:
           mysql-server depends on mysql-server-5.5; however:
         Package mysql-server-5.5 is not configured yet.
         dpkg: error processing mysql-server (--configure):
         dependency problems - leaving unconfigured
         No apport report written because the error message
         indicates its a followup error from a previous failure.
         Errors were encountered while processing:
           mysql-server-5.5
           mysql-server
         E: Sub-process /usr/bin/dpkg returned an error code (1)


    458  apt-get remove --purge mysql-server
         Reading package lists... Done
         Building dependency tree       
         Reading state information... Done
         The following packages will be REMOVED:
           mysql-server*
         0 upgraded, 0 newly installed, 1 to remove and 0 not upgraded.
         2 not fully installed or removed.
         After this operation, 116 kB disk space will be freed.
         Do you want to continue [Y/n]? 
         (Reading database ... 322159 files and directories
         currently installed.)
         Removing mysql-server ...
         Setting up mysql-server-5.5 (5.5.29-0ubuntu0.12.10.1) ...
         start: Job failed to start
         invoke-rc.d: initscript mysql, action "start" failed.
         dpkg: error processing mysql-server-5.5 (--configure):
         subprocess installed post-installation script
         returned error exit status 1
         Errors were encountered while processing:
           mysql-server-5.5
         E: Sub-process /usr/bin/dpkg returned an error code (1)

    461  touch /etc/apparmor.d/local/usr.sbin.mysqld
         (no output)

    462  service mysql start
         start: Job failed to start

Відповіді:


80

Спочатку видаліть MySQL:

sudo apt purge mysql-server mysql-client mysql-common
sudo apt autoremove
sudo mv -iv /var/lib/mysql /var/tmp/mysql-backup
sudo rm -rf /var/lib/mysql*

Потім перевстановіть:

sudo apt update
sudo apt install mysql-server
sudo mysql_install_db
sudo /usr/bin/mysql_secure_installation

1
ідеальне пояснення!
Postadelmaga

Я думаю, що варто згадати, що --purgeце не обов’язково те, що потрібно, оскільки воно також видалить конфігураційні файли. У випадку з mysql конкретно, мені цікаво, чи він також видалить dbs?
user50849

10
Щоб видалити конфігурацію та базу даних, вам доведеться видалити /etc/mysqlта /var/lib/mysql.
Енн ван Россум

2
Вам слід зупинити сервіс mysql, щоб видалити mysql-сервер
Віктор,

5
2017-05-20 15:12:01 [ПОПЕРЕДЖЕННЯ] mysql_install_db застаріло. Подумайте про перехід на mysqld --initialize
Flaudre

12

У Ubuntu 16.04 спосіб виправити це в моєму випадку ( спочатку скопіюйте резервні копії БД, бази даних будуть втрачені ):

sudo apt remove --purge mysql-server mysql-client mysql-common
sudo apt autoremove
sudo mv -iv /var/lib/mysql /var/tmp/mysql-backup
sudo rm -rf /var/lib/mysql*
sudo apt install mysql-server

(Якось, мої попередні дзвінки apt purge mysql-serverне здавалися успішними. Я вважав, що apt purge fooце рівнозначно apt remove --purge foo...)


Це видалення всіх баз даних. Якщо важливі дані, потрібна резервна копія.
мерехтіння

8

Я отримував такі самі помилки і намагався більшість кроків, які ви зробили, з однаковими результатами. Наступне нарешті спрацювало для мене.

apt-get purge mysql-server mysql-client mysql-common mysql-client-5.5 mysql-server-5.5

Після цього mysql встановлюється нормально.


1

Я не впевнений, що сталося зі мною, але інші рішення не спрацювали, і надалі помилка. Я спробував це apt-get purge mysql-*, потім autoremoveі autoclean. Після цього установка була в порядку.

**

Не забудьте зробити резервні копії ваших баз даних, наведена вище команда може також видалити їх

**


0

Якщо ти просто біжиш

sudo apt-get update
sudo apt-get install mysql-server

це оновить mysql, і це виправило проблему, яку я мав після оновлення до 16.04 lts.

Або просто бігати

sudo apt-get install lamp-server^

оновити всі серверні пакети.


0

Для версії MySQL 5.7 я видалив MySQL, як описано раніше:

sudo apt purge mysql-server mysql-client mysql-common
sudo apt autoremove
sudo rm -rf /var/lib/mysql*

І встановив його за допомогою:

sudo apt-get update
sudo apt-get install mysql-server
mysql_secure_installation

Щоб перевірити, чи все працює:

systemctl status mysql.service

джерело


-5

Встановіть phpMyAdmin із сховищ Ubuntu за замовчуванням. Потім запустіть:

dpkg --configure mysql-server-5.5
apt-get purge mysql-server mysql-client mysql-common mysql-client-5.5 mysql-server-5.5
apt-get autoremove
apt-get autoclean
apt-get update
apt-get install  mysql-server
service mysql restart

5
Навіщо встановлювати phpMyAdmin ? Це зовсім непотрібно.
Луціо
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.