Problemi nell'installazione e nella rimozione di MySQL in Ubuntu

22

Ho problemi con l'installazione o la rimozione del mysql-server-5.6 parzialmente installato in ubuntu15.04. L'errore che sto ottenendo è stato

$ sudo apt-get -f install 
Reading package lists... Done
Building dependency tree       
Reading state information... Done
The following extra packages will be installed:
  mysql-server-5.6
The following packages will be upgraded:
  mysql-server-5.6
1 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
22 not fully installed or removed.
Need to get 0 B/5,501 kB of archives.
After this operation, 50.8 MB of additional disk space will be used.
Do you want to continue? [Y/n] 
Preconfiguring packages ...
Setting up mysql-common (5.6.24-0ubuntu2) ...
update-alternatives: error: alternative path                 /etc/mysql/my.cnf.fallback doesn't exist
dpkg: error processing package mysql-common (--configure):
 subprocess installed post-installation script returned error exit status 2
Errors were encountered while processing:
 mysql-common
localepurge: Disk space freed in /usr/share/locale: 0 KiB
localepurge: Disk space freed in /usr/share/man: 0 KiB
localepurge: Disk space freed in /usr/share/gnome/help: 0 KiB
localepurge: Disk space freed in /usr/share/omf: 0 KiB
localepurge: Disk space freed in /usr/share/doc/kde/HTML: 0 KiB

Total disk space freed by localepurge: 0 KiB

E: Sub-process /usr/bin/dpkg returned an error code (1)

Qualcuno può aiutarmi in questo?

    
posta Shameerariff 01.07.2015 - 19:42

8 risposte

46

Prova a fare un errore, quindi reinstallalo.

sudo apt-get remove --purge mysql-\*
sudo apt-get install mysql-server mysql-client
    
risposta data sdkks 01.07.2015 - 20:08
10

Una soluzione molto semplice che io (il linux noob) ha dovuto scavare ... è creare il file.

nano /etc/mysql/my.cnf.fallback

e riempilo con il contenuto predefinito dal pacchetto mysql-common 5.7.11-0ubuntu6.

#
# The MySQL database server configuration file.
#
# You can copy this to one of:
# - "/etc/mysql/my.cnf" to set global options,
# - "~/.my.cnf" to set user-specific options.
# 
# One can use all long options that the program supports.
# Run program with --help to get a list of available options and with
# --print-defaults to see which it would actually understand and use.
#
# For explanations see
# http://dev.mysql.com/doc/mysql/en/server-system-variables.html

# This will be passed to all mysql clients
# It has been reported that passwords should be enclosed with ticks/quotes
# escpecially if they contain "#" chars...
# Remember to edit /etc/mysql/debian.cnf when changing the socket location.

# Here is entries for some specific programs
# The following values assume you have at least 32M ram

!includedir /etc/mysql/conf.d/

trovato qui su apt-browse.org

    
risposta data user636300 29.12.2016 - 21:51
9

Purge / Reinstall anche per me non ha funzionato. Ho trovato la seguente "soluzione":

Non ho trovato mysql.cnf.fallback elencato nei "file forniti" per mysql-server-5.6 / mysql-client-5.6 né altre informazioni aggiuntive sul file.

Ho copiato /etc/mysql/my.cnf in /etc/mysql/my.cnf.fallback (supponendo che questo sarebbe stato un file di configurazione "fallback" relativamente meno importante);

/etc/mysql/my.cnf è un link simbolico, quindi ls /etc/mysql ora mostra:

 my.cnf.fallback -> /etc/alternatives/my.cnf
 my.cnf -> /etc/alternatives/my.cnf

L'installazione del pacchetto è stata completata senza errori (poiché presumibilmente il problema "non esiste" è stato "risolto").

Non ho ancora riscontrato effetti negativi (ancora).

    
risposta data Jungle Editor 25.08.2015 - 11:41
2

Ho avuto lo stesso problema durante il tentativo di eliminare mysql-server (5.7.14).

Nel caso in cui mancano i file my.cnf *, puoi reinstallare il pacchetto mysql-common e successivamente puoi eliminare entrambi ( mysql-server & amp; mysql -Comune )

Questi file my.cnf * appartengono al pacchetto mysql-common (vedi sotto):

$ dpkg -L mysql-common | grep cnf
/etc/mysql/my.cnf.fallback
/etc/mysql/conf.d/mysql.cnf


 1. Reinstallare mysql-common

  

apt-get install --reinstall mysql-common

  1. Elimina mysql-common
  

apt-get purge mysql-common

    
risposta data ivanleoncz 30.08.2016 - 22:10
1

Ho controllato la mia cartella /etc/mysql/ e l'ho trovata completamente vuota diversa da una sottocartella vuota conf.d .

cd /etc/
# you need to delete the empty mysql folder otherwise the ln below creates the link inside the existing mysql folder
sudo rm -r mysql
sudo ln -s ./mysql.bak/ mysql

quindi (per gentile concessione di questo link questo link )

sudo dpkg --configure -a

e ora tutto sembra a posto.

Il link sopra menziona anche --force-depends ma non ho bisogno di questo. Inoltre menziona apt-get -f install ma di nuovo non ho avuto bisogno di questo.

    
risposta data northern-bradley 28.06.2016 - 22:48
0

Come notato da charneykaye nei commenti, questo approccio può fallire se ci sono alcuni processi mysql in background. Ho usato:

emil-mint-desktop ~ # ps -aef | grep mysql
root      6682     1  0 16:45 ?        00:00:00 sudo mysqld_safe --skip-grant-tables
root      6683  6682  0 16:45 ?        00:00:00 /bin/sh /usr/bin/mysqld_safe --skip-grant-tables
mysql     7046  6683  0 16:45 ?        00:00:01 /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --skip-grant-tables --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306 --log-syslog=1 --log-syslog-facility=daemon --log-syslog-tag=
root     21046  9812  0 17:32 pts/5    00:00:00 grep --color=auto mysql

Ha ucciso i primi 3 processi (l'ultimo è la grep chiamata stessa!) usando:

kill -9 6682 8883 7046

Quindi rimuovi tutto mysql correlato:

apt remove --purge mysql-\*
apt autoremove
apt autoclean

e quindi installa:

apt install mysql-server

Poi ha funzionato.

Versioni:

  • Mint 18.1 (basato su Ubuntu). Dovrai sostituire apt per apt-get per alcune altre versioni.
risposta data Deleet 23.06.2017 - 23:43
0

Ho trovato una soluzione semplice per questo:

Primo passo: apt-get install mysql-common --reinstall

Secondo passaggio: apt-get install mysql-server --reinstall

E funziona!

    
risposta data alefen 09.10.2017 - 13:01
0

Dopo aver provato tutte le risposte sopra ho potuto risolvere questo problema con:

sudo rm /etc/rc5.d/S03mysql

Quindi è stato in grado di eseguire:

sudo apt purge mysql-server mysql-server-5.7 mysql-server-core-5.7

sudo apt-get -f installa mysql-server --fix-missing --fix-broken

    
risposta data Kang the Conqueror 29.11.2017 - 09:47

Leggi altre domande sui tag