centos7 selinux开启下启动mysql失败:Can‘t change dir to

系统:centos7

selinux开启:

[user]$ sestatus
SELinux status:                 enabled
SELinuxfs mount:                /sys/fs/selinux
SELinux root directory:         /etc/selinux
Loaded policy name:             targeted
Current mode:                   permissive
Mode from config file:          disabled
Policy MLS status:              enabled
Policy deny_unknown status:     allowed
Max kernel policy version:      31
[user]$ getenforce
Permissive

启动Mysql命令

sudo systemctl start mysqld

#启动失败

#查看系统日志
sudo tail -f /var/log/messages
mysqld: mysqld: Can't change dir to '/home/test/mysql/data/' (Errcode: 13 - Permission denied)

按照官网修改了文件权限相关MySQL :: MySQL 5.7 Reference Manual :: 6.7.4 SELinux File Context

结果还是提示错误:Can't change dir to ‘新的datadir’。

经分析:是由于  /home/test/mysql/data目录,/home/test目录的权限不是root用户,/home/test/mysql/data目录的  ..操作权限也不是root用户,而使用sudo systemctl start mysql启动时,使用了root的用户,导致mysqld程序启动时,没有权限cd到/mysql/data目录。

处理办法

        mysql的新的数据目录,使用目录 /data/mysql。修改配置:/etc/my.cnf

        并拷贝原始数据:cp -a /var/lib/mysql /data/mysql

再次启动,完美解决!


版权声明:本文为wyhjia原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。