MySQL сервер не запускается из-за отсутствия разрешений, хотя они даны

MySQL сервер не запускается из-за отсутствия разрешений, хотя они даны

Я только что скопировал свой старый набор баз данных в /var/lib/mysql и получил что-то странное. Сначала разрешения были "root:root", потому что я использовал "sudo mc" для копирования резервной копии из резервной копии. Я запустил chmod и chown, чтобы подогнать старые разрешения, и даже сравнил с чистой установкой на другом компьютере, и разрешения должны быть в порядке. Однако я все еще получаю сообщение, что mysqld не может chdir в /var/lib/mysql

Вот вывод консоли:

thopiekar@gate:~$ sudo systemctl status mysql
● mysql.service - MySQL Community Server
   Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
   Active: activating (start-post) (Result: exit-code) since Di 2016-05-03 22:44:07 CEST; 15s ago
  Process: 9760 ExecStart=/usr/sbin/mysqld (code=exited, status=1/FAILURE)
  Process: 9754 ExecStartPre=/usr/share/mysql/mysql-systemd-start pre (code=exited, status=0/SUCCESS)
 Main PID: 9760 (code=exited, status=1/FAILURE);         : 9761 (mysql-systemd-s)
    Tasks: 2 (limit: 512)
   CGroup: /system.slice/mysql.service
           └─control
             ├─9761 /bin/bash /usr/share/mysql/mysql-systemd-start post
             └─9894 sleep 1

Mai 03 22:44:07 gate systemd[1]: Stopped MySQL Community Server.
Mai 03 22:44:07 gate systemd[1]: Starting MySQL Community Server...
Mai 03 22:44:08 gate mysqld[9760]: mysqld: Can't change dir to '/var/lib/mysql/' (Errcode: 13 - Permission denied)
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.130902Z 0 [Warning] Changed limits: max_open_files: 1024 (requested 5000)
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.131097Z 0 [Warning] Changed limits: table_open_cache: 431 (requested 2000)
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.274970Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.275222Z 0 [Warning] Can't create test file /var/lib/mysql/gate.lower-test
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.275449Z 0 [Note] /usr/sbin/mysqld (mysqld 5.7.11-0ubuntu6) starting as process 9760 ...
Mai 03 22:44:08 gate mysqld[9760]: 2016-05-03T20:44:08.285371Z 0 [Warning] Can't create test file /var/lib/mysql/gate.lower-test
Mai 03 22:44:08 gate systemd[1]: mysql.service: Main process exited, code=exited, status=1/FAILURE
thopiekar@gate:~$ sudo ls -la /var/lib/mysql/
insgesamt 145460
drw-r-----  8 mysql mysql     4096 Mai  3 22:29 .
drwxr-xr-x 87 root  root      4096 Apr 30 00:05 ..
-rw-r-----  1 mysql mysql       56 Apr 30 00:06 auto.cnf
-rw-r-----  1 mysql mysql        0 Apr 30 00:06 debian-5.7.flag
-rw-r-----  1 mysql mysql      657 Mai  2 10:33 ib_buffer_pool
-rw-r-----  1 mysql mysql 35651584 Mai  2 10:33 ibdata1
-rw-r-----  1 mysql mysql 50331648 Mai  3 22:29 ib_logfile0
-rw-r-----  1 mysql mysql 50331648 Apr 29 15:08 ib_logfile1
-rw-r-----  1 mysql mysql 12582912 Mai  3 22:29 ibtmp1
drwxr-x---  2 mysql mysql     4096 Apr 30 00:06 mysql
drwxr-x---  2 mysql mysql     4096 Mai  2 09:46 MXYZ
drwxr-x---  2 mysql mysql     4096 Apr 30 00:06 performance_schema
drwxr-x---  2 mysql mysql    12288 Apr 30 00:06 sys
drwxr-x---  2 mysql mysql     4096 Apr 29 15:08 XY
drwxr-x---  2 mysql mysql     4096 Apr 29 15:08 XYZ

Кто-нибудь может мне это объяснить? Спасибо!

решение1

Вы заявили, что вы "только что скопировал свой старый набор баз данных" Слово "копирование" в этой ситуации может означать неправильный подход. Конечно, ваш "копирование" возможно, включали другие нераскрытые шаги. MySQL, кажется, структурирован так, чтобыэкспортваши базы данных и затемИмпортироватьих в "новый"база данных. Не фактическое копирование.

У вас все еще работает исходная конфигурация MySQL? Базы данных все еще там и доступны?

Установлен ли MySQL на вашей «новой» системе?

У вас установлен phpMyAdmin? Если нет, посмотрите, как им пользоватьсяmysqldump.

Если доступен phpMyAdmin, используйте phpMyAdmin для экспорта баз данных. После этого скопируйте вывод в папку загрузки "новый" компьютерная система.

На "новый" компьютерная система, снова используйте phpMyAdmin, но в этом случае для импорта баз данных из папки загрузки. Импорт ваших баз данных должен решить вашу проблему с правами доступа.

Для получения дополнительных более подробных инструкций по экспорту/импорту выполните поиск в Интернете по запросу "mysql экспорт баз данных".

Вот пример случайного выбора, основанный на использовании mysqldump: "Экспорт и импорт всех баз данных MySQL одновременно"

Связанный контент