MySQL的坑 Can't find file: './mysql/plugin.frm' 问题

原创 2017年09月15日 21:32:54

MySQL的磁盘满了,将数据库目录data移动到/data3目录,/etc/my.cnf里面也修改了相应的datadir目录,权限也赋予了,但是service mysql start;的时候报错,error log显示如下:

2017-09-15 16:01:01 2420 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead.
2017-09-15 16:01:01 2420 [Note] Plugin 'FEDERATED' is disabled.
^G/usr/sbin/mysqld: Can't find file: './mysql/plugin.frm' (errno: 13 - Permission denied)
2017-09-15 16:01:01 2420 [ERROR] Can't open the mysql.plugin table. Please run mysql_upgrade to create it.
2017-09-15 16:01:01 2420 [Note] InnoDB: Using atomics to ref count buffer pool pages
2017-09-15 16:01:01 2420 [Note] InnoDB: The InnoDB memory heap is disabled
2017-09-15 16:01:01 2420 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins
2017-09-15 16:01:01 2420 [Note] InnoDB: Memory barrier is not used
2017-09-15 16:01:01 2420 [Note] InnoDB: Compressed tables use zlib 1.2.8
2017-09-15 16:01:01 2420 [Note] InnoDB: Using Linux native AIO
2017-09-15 16:01:01 2420 [Note] InnoDB: Using CPU crc32 instructions
2017-09-15 16:01:01 2420 [Note] InnoDB: Initializing buffer pool, size = 128.0M
2017-09-15 16:01:02 2420 [Note] InnoDB: Completed initialization of buffer pool
2017-09-15 16:01:02 2420 [ERROR] InnoDB: ./ibdata1 can't be opened in read-write mode
2017-09-15 16:01:02 2420 [ERROR] InnoDB: The system tablespace must be writable!
2017-09-15 16:01:02 2420 [ERROR] Plugin 'InnoDB' init function returned error.
2017-09-15 16:01:02 2420 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2017-09-15 16:01:02 2420 [ERROR] Unknown/unsupported storage engine: InnoDB
2017-09-15 16:01:02 2420 [ERROR] Aborting


去先检查plugin.frm权限,发现有权限,也是mysql属主:

root@hutaojie-1-pdd-sh:/data1/mysql/mysql# ll plugin.*
-rwxrwxrwx 1 mysql mysql 8586 Mar  6  2016 plugin.frm*
-rwxrwx--x 1 mysql mysql  116 Mar  6  2016 plugin.MYD*
-rwxrwx--x 1 mysql mysql 2048 Mar  6  2016 plugin.MYI*
root@hutaojie-1-pdd-sh:/data1/mysql/mysql#


google之后发现,原来问题在os这里,ubatu的mysql通过yum安装或者rpm安装的时候,会建一个/etc/apparmor.d/usr.sbin.mysqld 文件,如果数据目录不在这里面,则会报错,

/usr/sbin/mysqld: Can’t find file: ‘./mysql/plugin.frm’ (errno: 13 - Permission denied)


所以解决办法是在里面加上新的datadir目录。

root@huayuan:/var/lib# vim /etc/apparmor.d/usr.sbin.mysqld 

# vim:syntax=apparmor
# Last Modified: Tue Jun 19 17:37:30 2007
#include <tunables/global>

/usr/sbin/mysqld {
  #include <abstractions/base>
  #include <abstractions/nameservice>
  #include <abstractions/user-tmp>
  #include <abstractions/mysql>
  #include <abstractions/winbind>

  capability dac_override,
  capability sys_resource,
  capability setgid,
  capability setuid,

  network tcp,

  /run/mysqld/mysqld.pid rw,
  /run/mysqld/mysqld.sock w,

  /sys/devices/system/cpu/ r,
  #.........这里面写新的datadir目录,写2行,一行r,一行rwk。
  /data3/mysql/ r,
  /data3/mysql/** rwk,
  # Site-specific additions and overrides. See local/README for details.
  #include <local/usr.sbin.mysqld>
}


然后重启mysql实例,ok,问题解决。

MySQL的坑 Can't find file: './mysql/plugin.frm' 问题

MySQL的磁盘满了,将数据库目录data移动到/data3目录,/etc/my.cnf里面也修改了相应的datadir目录,权限也赋予了,但是service mysql start;的时候报错,er...
  • kwame211
  • kwame211
  • 2017年09月22日 09:21
  • 539

URL中传参带有%2F等特殊字符

用URL传参带特殊字符,特殊字符丢失,比如传参的时候,用&符号连接,如果其中的一个参数中含有 # $ ^ & * + - 这些符号的时候,在另一个页面getParameter就会取不到穿过来的参数。 ...
  • I_Am_Zou
  • I_Am_Zou
  • 2016年09月21日 10:33
  • 4269

/usr/sbin/mysqld: Can't find file: './mysql/plugin.frm' (errno: 13)

[root@localhost ~]# /etc/init.d/mysqld start MySQL Daemon failed to start. 正在启动 mysqld: ...
  • yongchaocsdn
  • yongchaocsdn
  • 2018年01月07日 21:56
  • 97

启动mysql报错Can't find file: './mysql/plugin.frm'

启动mysql报错Can't find file: './mysql/plugin.frm' 重启mysql以后突然报错,详情如下: 171122 19:08:18 [ERROR] mysqld:...
  • sunny05296
  • sunny05296
  • 2017年11月22日 19:21
  • 299

/usr/sbin/mysqld: Can't find file: './mysql/plugin.frm' (errno: 13)

150424 12:41:44 [Warning] Using unique option prefix myisam-recover instead of myisam-recover-option...
  • xugangwen
  • xugangwen
  • 2015年04月24日 14:03
  • 11279

iOS 将http%3A%2F%2F解析为URL

NSString *str = @"http%3A%2F%2Fmyimg.ifeng.com%2F200%2F22%2F8a941d71c4df48a5%2F1418632228%2F8a941d71...
  • worldzhy
  • worldzhy
  • 2014年12月15日 17:37
  • 9783

de/encodeURI(Component)--"http%3A%2F%2Fwww.baidu.com%2Fasd%3Fa%3D123"

对于”http%3A%2F%2Fwww.baidu.com%2Fasd%3Fa%3D123”这种特殊字符被转义成16进制的字符串, 虽然知道”%3A”表示冒号(百分号”%”是转义符, 相当于正则当中的...
  • gong_zhe_511
  • gong_zhe_511
  • 2017年04月25日 11:28
  • 2504

/usr/local/mysql/bin/mysqld: Can't find file: './mysql/plugin.frm' (errno: 13 - Permission denied) 2

第一次报错: Can't connect to local MySQL server through socket '/tmp/mysql.sock 尝试解决的时候发现找不到mysql.sock这个...
  • qq_40454655
  • qq_40454655
  • 2018年01月09日 14:51
  • 57

[ERROR] Can't find messagefile '/usr/bin/share/mysql/errmsg.sys'

[ERROR] Can't find messagefile '/usr/bin/share/mysql/errmsg.sys' 解决办法 cp errmsg.sys /usr...
  • lsm135
  • lsm135
  • 2015年10月10日 18:15
  • 1022

hidden32.exe

  进程知识库 hidden32 - hidden32.exe - 进程信息进程文件: hidden32 或者 hidden32.exe进程名称: hidden32  描述:hidden32.exe是...
  • ProcessInfo
  • ProcessInfo
  • 2007年12月03日 13:25
  • 335
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MySQL的坑 Can't find file: './mysql/plugin.frm' 问题
举报原因:
原因补充:

(最多只允许输入30个字)