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,问题解决。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

GitHub 的 12 个实用技巧,你 get 了几个?

GitHub 实用技巧总结。

开发者山行图,找到你的收入和位置

开发者山行图,找找你所处的位置,看看你的收入。

解决VS2010 command prompt error:nmake 不是内部或外部命令,也不是可运行的程序或批处理文件

 在我的Path:“c:\windows\system32″

windows搭建libssh2+VS2005开发环境

1.准备工具 1.1 VS2005 1.2 安装脚本语言ActivePerl http://www.activestate.com/ActivePerl下载,安装即可 1.3 配置环境变量,将p...

关于 varchar max的误区

在论坛或者qq群里都会遇到有人问,类似 varchar(max)不够存字符串的长度怎么办?有的人会说改成text的数据类型。那真相是什么呢?

Windows10下安装OpenSSL

做毕业设计需要用到OpenSSL,但在网上没找到比较理想的安装方法,因此我综合Windows系列的安装方法完成Windows10的方法 安装环境:Windows10专业版+VS2013 工具:Acti...

OpenSSL+zlib+libssh2编译(windows)

由于项目需要,需要在windows上构建sftp的客户端,索性把这三个东西集成到windows的解决方案中。 OpenSLL编译 1.需要安装perl环境,去ActivePerl官网上下载Activ...

nmake命令(windows下的makefile)

1. 如果已经有vc6的dsp工程,可直接导出nmake脚本文件(.mak)     “Project - Export Makefile...” nmake -f nMakeTest.m...

SFTP客户端代码示例

SFTP客户端代码示例 环境:libssh2 1.4.3、zlib-1.2.8、openssl-1.0.1g Author: Kagula 最后更新日期:2014-5-18          ...

'nmake' 不是内部或外部命令,也不是可运行的程序 或批处理文件。

今天想使用vs2010 执行notepad++ 源码的时候发现需要先生成Scintilla的Scintilla.dll文件。于是执行nmake发现不是内部命令各种折腾各种问题各种坑。 其实需要运行nm...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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