Estou tentando instalar o mysql-server-5.7 no Kubuntu 16.04, mas estou tendo problemas.
sudo apt install mysql-server
dá a seguinte saída.
Setting up mysql-server-5.7 (5.7.18-0ubuntu0.16.04.1) ...
Renaming removed key_buffer and myisam-recover options (if present)
Job for mysql.service failed because the control process exited with error code. See "systemctl status mysql.service" and "journalctl -xe" for details.
invoke-rc.d: initscript mysql, action "start" failed.
● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: activating (auto-restart) (Result: exit-code) since ons 2017-05-17 09:48:39 CEST; 10ms ago
Process: 13622 ExecStartPost=/usr/share/mysql/mysql-systemd-start post (code=exited, status=0/SUCCESS)
Process: 13621 ExecStart=/usr/sbin/mysqld (code=exited, status=2)
Process: 13612 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
Main PID: 13621 (code=exited, status=2)
maj 17 09:48:39 anis systemd[1]: Failed to start MySQL Community Server.
maj 17 09:48:39 anis systemd[1]: mysql.service: Unit entered failed state.
maj 17 09:48:39 anis systemd[1]: mysql.service: Failed with result 'exit-code'.
dpkg: error processing package mysql-server-5.7 (--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.7; however:
Package mysql-server-5.7 is not configured yet.
dpkg: error processing package mysql-server (--configure):
dependency problems - leaving unconfigured
Errors were encountered while processing:
mysql-server-5.7
mysql-server
E: Sub-process /usr/bin/dpkg returned an error code (1)
E ao tentar solucionar problemas executando journalctl -xe
, recebo resultados como os seguintes, o que parece indicar que o AppArmor está me causando problemas.
maj 17 09:53:14 anis systemd[1]: Starting MySQL Community Server...
-- Subject: Unit mysql.service has begun start-up
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit mysql.service has begun starting up.
maj 17 09:53:14 anis audit[14767]: AVC apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/status" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis audit[14767]: AVC apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/sys/devices/system/node/" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=0
maj 17 09:53:14 anis kernel: audit: type=1400 audit(1495007594.314:240): apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/status" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis kernel: audit: type=1400 audit(1495007594.314:241): apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/sys/devices/system/node/" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=0
maj 17 09:53:14 anis kernel: audit: type=1400 audit(1495007594.314:242): apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/status" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis audit[14767]: AVC apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/status" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis audit[14767]: AVC apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/task/14767/mem" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis kernel: audit: type=1400 audit(1495007594.658:243): apparmor="DENIED" operation="open" profile="/usr/sbin/mysqld" name="/proc/14767/task/14767/mem" pid=14767 comm="mysqld" requested_mask="r" denied_mask="r" fsuid=124 ouid=124
maj 17 09:53:14 anis systemd[1]: mysql.service: Main process exited, code=exited, status=2/INVALIDARGUMENT
Como eu poderia resolver esse problema?
/var/log/mysql/error.log
. O MySQL ainda deve ser capaz de executar, mesmo que não possa acessar os arquivos / proc e / sys acima.Respostas:
Você precisa editar sua configuração do apparmor para permitir que o MySQL acesse esses arquivos. As mensagens de log estão dizendo que
/usr/sbin/mysqld
as necessidades ler (r
) acesso a aberta/proc/14767/status
,/sys/devices/system/node/
(barra invertida porque quer ler o diretório), e/proc/14767/task/14767/mem
. O arquivo a ser editado é/etc/apparmor.d/usr.sbin.mysqld
.No meu caso, resolvi o problema adicionando essas linhas em algum lugar no meio (com dois espaços na frente de cada uma):
(Observe a barra à direita da segunda linha.)
Depois de fazer isso, tente iniciar o MySQL e, se você receber mais erros, adicione esses arquivos também e tente novamente.
Aqui está uma resposta que eu dei para esse problema em outro lugar.
fonte
apparmour
configurações manualmente para instalarmysql
, se for esse o caso, há um problema./proc/*/status r
está desnecessariamente aberto. O Apparmor possui correspondências para o preço atual, portanto, você pode fazer o seguinte:@{PROC}/@{pid}/status r,
Você também pode querer acessar caracteres curinganode*/meminfo
se tiver suporte NUMA / mais de uma CPU exposta à máquina.sudo service apparmor restart
/etc/apparmor.d/local/user.sbin/mysqld
vez de evitar conflitos com as atualizações de perfil padrão. Ele já está incluído no perfil padrãoPode ser o seguinte: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=739846, então tente usar
se não estiver ajudando no uso:
remover completamente o mysql e reinstalar Aviso: Se você tiver algum banco de dados, ele será removido.
fonte
exit 0
no final. Eu tentei limpar e reinstalar o mysql-server, o que não ajudou. Eu apenas tentei reinstalar (sem limpar) o mysql-common, o que também não ajudou. Para removê-lo, será necessário desinstalar muitos pacotes que dependem dele, dos quais tenho um pouco de medo.sudo apt remove --purge mysql-*
para remover completamente todas as coisas do MySQL (eu tenho a versão 5.7) e depois o fizsudo apt install akonadi-server mysql-client mysql-server
, mas o resultado ainda é o mesmo. Ainda recebo a mesma mensagem de erro ejournalctl -xe
indica um problema do AppArmor como acima.Eu resolvi esse problema com isso;
Edite /etc/apparmor.d/local/usr.sbin.mysqld
Adicione estas linhas;
recarregar o serviço apparmor
fonte
No meu caso, tentando instalar o mysql-server-5.7 no Ubuntu 16.04 depois de usar as respostas acima, o que funcionou foi:
sudo apt install mysql-server
sudo apt install mysql-server
novamente para continuar a instalaçãoInstalação completa.
fonte
stop mysql-server
rm /var/lib/mysql/ib_logfile*
restart mysql
fonte
{}
de código para torná-lo mais legível. Você pode editar sua resposta.ib_logfile*
arquivos e o fiz,apt upgrade
mas quando o apt chegou ao mysql, obtive a seguinte saídamysql_upgrade: [ERROR] 1812: Tablespace is missing for table mysql.plugin