自 Debian 9 以来无法更改 MariaDB 数据目录

自 Debian 9 以来无法更改 MariaDB 数据目录

我在 debian 8 上已执行了 1000 次,但自从在 debian 9 上尝试后就没有成功。

我想更改 mariadb 的默认数据目录,以下是从原始 debian 9 VM 执行的过程:

apt-get update && apt-get install mariadb-server mariadb-client
service mysql stop
rsync -av /var/lib/mysql /home/
vi /etc/mysql/mariadb.conf.d/50-server.cnf

grep -r datadir /etc/mysql/
/etc/mysql/mariadb.conf.d/50-server.cnf:datadir     = /home/mysql   

[11:29:32]root@deb9: ~ # ls -la /home/mysql/
drwxr-xr-x 4 mysql mysql     4096 Sep  7 11:25 .
drwxr-xr-x 3 root  root      4096 Sep  7 11:25 ..
-rw-rw---- 1 mysql mysql    16384 Sep  7 11:25 aria_log.00000001
-rw-rw---- 1 mysql mysql       52 Sep  7 11:25 aria_log_control
-rw-r--r-- 1 root  root         0 Sep  7 11:25 debian-10.1.flag
-rw-rw---- 1 mysql mysql 12582912 Sep  7 11:25 ibdata1
-rw-rw---- 1 mysql mysql 50331648 Sep  7 11:25 ib_logfile0
-rw-rw---- 1 mysql mysql 50331648 Sep  7 11:25 ib_logfile1
-rw-rw---- 1 mysql mysql        0 Sep  7 11:25 multi-master.info
drwx------ 2 mysql root      4096 Sep  7 11:25 mysql
drwx------ 2 mysql mysql     4096 Sep  7 11:25 performance_schema

service mysql start


Sep  7 09:27:44 debian systemd[1]: Starting MariaDB database server...
Sep  7 09:27:44 debian mysqld[15106]: 2017-09-07 11:27:44 140699007124032 [Note] /usr/sbin/mysqld (mysqld 10.1.26-MariaDB-0+deb9u1) starting as process 15106 ...
Sep  7 09:27:44 debian mysqld[15106]: 2017-09-07 11:27:44 140699007124032 [Warning] Can't create test file /home/mysql/deb9.lower-test
Sep  7 09:27:44 debian mysqld[15106]: #007/usr/sbin/mysqld: Can't change dir to '/home/mysql/' (Errcode: 13 "Permission denied")
Sep  7 09:27:44 debian mysqld[15106]: 2017-09-07 11:27:44 140699007124032 [ERROR] Aborting
Sep  7 09:27:44 debian systemd[1]: mariadb.service: Main process exited, code=exited, status=1/FAILURE

如您所见,错误是没有权限 有些帖子谈到应用装甲但是这个没有在进程列表上运行,我也没有触及它的任何内容。

grep -r maria /etc/apparmor
grep -r mysql /etc/apparmor

不返回任何内容。

我也不使用 SELINUX...

感谢您的帮助。

答案1

问题是设置了systemd服务文件mariadb.service

ProtectHome = true

默认情况下。此设置阻止服务访问/家/根/运行/用户目錄。

因此,您要么将mysql数据安装到其他位置,要么将此功能设置为false

要禁用此功能,最好使用systemctl edit mariadb打开环境变量中定义的编辑器EDITOR。只需输入

[Service]
ProtectHome = false

在该编辑器中。保存并关闭,/etc/systemd/system/mariadb.service.d/override.conf将创建一个覆盖文件。之后systemctl daemon-reload需要重新读取设置。启动您的服务。

相关内容