cant find file mysql plugin.frm_MySQL中报错:Can’t find file: ‘./mysql/plugin.frm’的解决方法...

发现问题

最近在工作中发现了一个问题,这个问题就是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权限,frm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果出现特殊情况出现frm文件损坏也不要放弃希望,当完善MyISAM和InnoDB表时,MySQL服务会首先去调用frm文件,所以我们只能通过完善frm文件进行后面的数据恢复。

然后我们发现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

/usr/sbin/mysqld {

#include

#include

#include

#include

#include

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

}

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习网上卖,如果有疑问大家可以留言交流,谢谢大家对乐购源码的支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用、引用和引用的内容,"ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/data/mysql/mysql.sock' (111)"这个错误提示是由于无法通过指定的MySQL socket连接到本地MySQL服务器引起的。 解决这个问题的方法可以包括以下几个步骤: 1. 确认MySQL服务器是否正在运行。可以使用命令"service mysql status"或"systemctl status mysql"来检查MySQL服务的状态。如果MySQL服务未运行,可以使用命令"service mysql start"或"systemctl start mysql"来启动它。 2. 确认MySQL socket文件的路径是否正确。根据错误提示的路径"/data/mysql/mysql.sock",请确保该路径下存在正确的socket文件。如果路径不正确,可以尝试使用正确的路径来连接MySQL服务器。 3. 检查MySQL配置文件的socket设置。可以使用命令"cat /etc/my.cnf"或"cat /etc/mysql/my.cnf"来查看MySQL配置文件。确认"socket"参数的值是否与实际socket文件的路径一致。如果不一致,可以修改配置文件并重启MySQL服务。 4. 如果以上步骤都没有解决问题,可能是由于MySQL服务器的其他配置问题导致无法连接。可以尝试重新安装MySQL服务器或联系服务器管理员进行进一步的故障排除。 总结起来,解决"ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/data/mysql/mysql.sock' (111)"错误的方法包括确认MySQL服务是否运行、检查socket文件路径、检查MySQL配置文件的socket设置,并进行必要的修复或重新安装。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [ERROR 2002 (HY000): Cant connect to local MySQL server through socket的解决方法](https://blog.csdn.net/coco3600/article/details/100231949)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [ERROR 2002 (HY000): Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock...](https://blog.csdn.net/weixin_45777669/article/details/115671283)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值