mysqldump –tab (ErrCode:13-Permission denied) 问题解决

在 mysql 服务器上,可以通过 load data infile ‘file_name’ into table table_name; 命令将一个文本文件中的所有数据存到指定表中。最粗略形式的例子:
load data infile ‘test.txt’ into table test_table;
默认情况下,load data infile 对于文本中行为是:

一行对应数据库表中的一条记录 各个字段之间以 tab 键分开 每个字段的值没有被任何字符括起来 行没有前缀可以忽略

比如某一行文本:

1 test “xx”


读入数据库之后,第三个字段的值是 “xx”,而不是 xx

就算改变了 test.txt 文件的访问权限,例如 chmod o+r test.txt 依然会出现上述问题。要解决这个问题会扯到 AppArmor。这是一个保护机制,限制每个程序对特定目录和文件的访问权限。也即是说,当前 mysql 程序访问这个文件的权限被 AppArmor 限制住了。关于 AppArmor 参考第二条链接(维基百科)。
真正可以做的是给 mysql 程序读取这个文件的权限,按照以下几个步骤可以做到:
1)打开 /etc/apparmor.d/usr.sbin.mysqld 文件
2)此时能看到很多关于 mysql 能够读写为目录和文件的记录,比如:

/usr/sbin/mysqld {
    #Other contents
    /var/log/mysql.log rw,
    /var/log/mysql.err rw,
 
    #Other contents
 
    #This will be your dir definition
    /tmp/ r,
    /tmp/** rw,
 
    #Other contents
}

在最后加上需要读写的文件的相应权限,保存并退出。
3)重新导入 AppArmor 配置,利用 /etc/init.d/apparmor reload 命令
4)重新启动 mysql,利用 service mysql restart 命令
至此问题应该解决了。不过这可能是个不安全的解决办法,需要慎重