系统: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
再次启动,完美解决!