MySQL instala anulações com erro

0

Estou tentando instalar o MySQL no Raspbian Jessie. Isso funcionou sem problemas em outra máquina com configuração idêntica; no entanto, no segundo, não consigo fazer funcionar.

Durante a configuração do pacote, sou solicitado a fornecer uma senha e, depois de esperar, recebo:

┌─────────────────────────────────────┤ Configuring mysql-server-5.5 ├──────────────────────────────────────┐    
│                                                                                                           │    
│ Unable to set password for the MySQL "root" user                                                          │    
│                                                                                                           │    
│ An error occurred while setting the password for the MySQL administrative user. This may have happened    │    
│ because the account already has a password, or because of a communication problem with the MySQL server.  │    
│                                                                                                           │    
│ You should check the account's password after the package installation.                                   │    
│                                                                                                           │    
│ Please read the /usr/share/doc/mysql-server-5.5/README.Debian file for more information.                  │    
│                                                                                                           │    
│                                                  <Ok>                                                     │    
│                                                                                                           │    
└───────────────────────────────────────────────────────────────────────────────────────────────────────────┘    

Indo um pouco mais a fundo, descobri que esse erro foi causado pelo fracasso do MySQL em iniciar. Eu examinei /var/log/mysql/error.log , que tem as seguintes entradas:

161217 23:33:16 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
161217 23:33:16 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
161217 23:33:17 [Note] /usr/sbin/mysqld (mysqld 5.5.53-0+deb8u1) starting as process 16476 ...
161217 23:33:17 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead.
161217 23:33:17 [Note] Plugin 'FEDERATED' is disabled.
161217 23:33:17 InnoDB: The InnoDB memory heap is disabled
161217 23:33:17 InnoDB: Mutexes and rw_locks use GCC atomic builtins
161217 23:33:17 InnoDB: Compressed tables use zlib 1.2.8
161217 23:33:17 InnoDB: Using Linux native AIO
161217 23:33:17 InnoDB: Initializing buffer pool, size = 128.0M
161217 23:33:17 InnoDB: Completed initialization of buffer pool
InnoDB: Error: auto-extending data file ./ibdata1 is of a different size
InnoDB: 0 pages (rounded down to MB) than specified in the .cnf file:
InnoDB: initial 640 pages, max 0 (relevant if non-zero) pages!
161217 23:33:17 InnoDB: Could not open or create data files.
161217 23:33:17 InnoDB: If you tried to add new data files, and it failed here,
161217 23:33:17 InnoDB: you should now edit innodb_data_file_path in my.cnf back
161217 23:33:17 InnoDB: to what it was, and remove the new ibdata files InnoDB created
161217 23:33:17 InnoDB: in this failed attempt. InnoDB only wrote those files full of
161217 23:33:17 InnoDB: zeros, but did not yet use them in any way. But be careful: do not
161217 23:33:17 InnoDB: remove old data files which contain your precious data!
161217 23:33:17 [ERROR] Plugin 'InnoDB' init function returned error.
161217 23:33:17 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
161217 23:33:17 [ERROR] Unknown/unsupported storage engine: InnoDB
161217 23:33:17 [ERROR] Aborting

161217 23:33:17 [Note] /usr/sbin/mysqld: Shutdown complete

161217 23:33:18 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended

Esta não é uma atualização, mas uma nova instalação (além disso, tentei instalar o MySQL algumas vezes, removendo mysql-server-5.5 entre as tentativas).

Devo mencionar, no entanto, que fiquei sem espaço de armazenamento na primeira tentativa (a partição raiz estava em algum lugar com menos de 2 GB). Eu tentei consertar isso substituindo o cartão SD de 2 GB por um cartão de 16 GB, dd 'ing o conteúdo do antigo para o novo e estendendo a partição. Ainda não consigo fazer isso funcionar, enquanto o primeiro sistema (que tinha um cartão de 4 GB desde o início) funcionou muito bem. Qual é o problema aqui e como posso corrigi-lo?

    
por user149408 17.12.2016 / 23:54

1 resposta

2

Aparentemente, o problema foi causado pela falta de espaço de armazenamento durante a primeira tentativa: o MySQL tentou criar um arquivo de dados, que falhou devido a espaço insuficiente e deixou um arquivo de dados corrompido, bem como um arquivo de configuração apontando para ele .

IIRC minha primeira tentativa foi em sudo apt-get remove MySQL e reinstalar, o que deixou o arquivo de dados defeituoso e a configuração por trás, então a próxima instalação iria pegá-lo e falhar da mesma maneira.

Aparentemente, mesmo um sudo apt-get purge mysql-server-5.5 subseqüente não removeu esses itens. A seguinte sequência de comandos finalmente fez o truque para mim:

sudo apt-get purge mysql-server-5.5
sudo rm -R /etc/mysql
sudo rm -R /var/lib/mysql
sudo apt-get install mysql-server

Depois disso, o MySQL apareceu e eu pude acessar o console do MySQL.

Importante: Isso irá apagar permanentemente todos os dados do MySQL em seu sistema. Faça isso somente em uma nova instalação ou se você estiver ciente das conseqüências.

    
por 18.12.2016 / 00:19