数据库教程:MySQL中报错:Can’t find file: ‘./mysql/plugin.frm’的解决方法分享

发现问题

最近在工作中发现了一个问题,这个问题就是MySQL的磁盘满了,将数据库目录data移动到/data3目录,/etc/my.cnf里面也修改了相应的datadir目录,权限也赋予了,但是servicemysqlstart;的时候报错,下面话不多说了,来一起看看详细的解决方法吧。

errorlog显示如下:

2017-09-1516:01:012420[Warning]Usinguniqueoptionprefixmyisam-recoverinsteadofmyisam-recover-optionsisdeprecatedandwillberemovedinafuturerelease.Pleaseusethefullnameinstead. 2017-09-1516:01:012420[Note]Plugin'FEDERATED'isdisabled. ^G/usr/sbin/mysqld:Can'tfindfile:'./mysql/plugin.frm'(errno:13-Permissiondenied) 2017-09-1516:01:012420[ERROR]Can'topenthemysql.plugintable.Pleaserunmysql_upgradetocreateit. 2017-09-1516:01:012420[Note]InnoDB:Usingatomicstorefcountbufferpoolpages 2017-09-1516:01:012420[Note]InnoDB:TheInnoDBmemoryheapisdisabled 2017-09-1516:01:012420[Note]InnoDB:Mutexesandrw_locksuseGCCatomicbuiltins 2017-09-1516:01:012420[Note]InnoDB:Memorybarrierisnotused 2017-09-1516:01:012420[Note]InnoDB:Compressedtablesusezlib1.2.8 2017-09-1516:01:012420[Note]InnoDB:UsingLinuxnativeAIO 2017-09-1516:01:012420[Note]InnoDB:UsingCPUcrc32instructions 2017-09-1516:01:012420[Note]InnoDB:Initializingbufferpool,size=128.0M 2017-09-1516:01:022420[Note]InnoDB:Completedinitializationofbufferpool 2017-09-1516:01:022420[ERROR]InnoDB:./ibdata1can'tbeopenedinread-writemode 2017-09-1516:01:022420[ERROR]InnoDB:Thesystemtablespacemustbewritable! 2017-09-1516:01:022420[ERROR]Plugin'InnoDB'initfunctionreturnederror. 2017-09-1516:01:022420[ERROR]Plugin'InnoDB'registrationasaSTORAGEENGINEfailed. 2017-09-1516:01:022420[ERROR]Unknown/unsupportedstorageengine:InnoDB 2017-09-1516:01:022420[ERROR]Aborting

去先检查plugin.frm权限,frm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果出现特殊情况出现frm文件损坏也不要放弃希望,当修复MyISAM和InnoDB表时,MySQL服务会首先去调用frm文件,所以我们只能通过修复frm文件进行后面的数据恢复。

然后我们发现plugin.frm有权限,也是mysql属主:

root@hutaojie-1-pdd-sh:/data1/mysql/mysql#llplugin.* -rwxrwxrwx1mysqlmysql8586Mar62016plugin.frm* -rwxrwx--x1mysqlmysql116Mar62016plugin.MYD* -rwxrwx--x1mysqlmysql2048Mar62016plugin.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'tfindfile:‘./mysql/plugin.frm'(errno:13-Permissiondenied)

解决方法

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

root@huayuan:/var/lib#vim/etc/apparmor.d/usr.sbin.mysqld #vim:syntax=apparmor #LastModified:TueJun1917:37:302007 #include<tunables/global> /usr/sbin/mysqld{ #include<abstractions/base> #include<abstractions/nameservice> #include<abstractions/user-tmp> #include<abstractions/mysql> #include<abstractions/winbind> capabilitydac_override, capabilitysys_resource, capabilitysetgid, capabilitysetuid, networktcp, /run/mysqld/mysqld.pidrw, /run/mysqld/mysqld.sockw, /sys/devices/system/cpu/r, #.........这里面写新的datadir目录,写2行,一行r,一行rwk。 /data3/mysql/r, /data3/mysql/**rwk, #Site-specificadditionsandoverrides.Seelocal/READMEfordetails. #include<local/usr.sbin.mysqld> }

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

上述就是数据库技术:MySQL中报错:Can’t find file: ‘./mysql/plugin.frm’的解决方法分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/914651.html

(0)
上一篇 2021年10月29日
下一篇 2021年10月29日

精彩推荐