主頁 > 知識(shí)庫 > MySQL中報(bào)錯(cuò):Can’t find file: ‘./mysql/plugin.frm’的解決方法

MySQL中報(bào)錯(cuò):Can’t find file: ‘./mysql/plugin.frm’的解決方法

熱門標(biāo)簽:怎么申請400電話申請 電銷機(jī)器人價(jià)格多少錢一臺(tái) 龍圖酒吧地圖標(biāo)注 好搜地圖標(biāo)注 怎么辦理400電話呢 400電話申請什么好 百度地圖標(biāo)注地方備注 電話機(jī)器人免費(fèi)嗎 地圖標(biāo)注圖標(biāo)素材入駐

發(fā)現(xiàn)問題

最近在工作中發(fā)現(xiàn)了一個(gè)問題,這個(gè)問題就是MySQL的磁盤滿了,將數(shù)據(jù)庫目錄data移動(dòng)到/data3目錄,/etc/my.cnf里面也修改了相應(yīng)的datadir目錄,權(quán)限也賦予了,但是service mysql start;的時(shí)候報(bào)錯(cuò),下面話不多說了,來一起看看詳細(xì)的解決方法吧。

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權(quán)限,frm是MySQL表結(jié)構(gòu)定義文件,通常frm文件是不會(huì)損壞的,但是如果出現(xiàn)特殊情況出現(xiàn)frm文件損壞也不要放棄希望,當(dāng)修復(fù)MyISAM和InnoDB表時(shí),MySQL服務(wù)會(huì)首先去調(diào)用frm文件,所以我們只能通過修復(fù)frm文件進(jìn)行后面的數(shù)據(jù)恢復(fù)。

然后我們發(fā)現(xiàn)plugin.frm有權(quán)限,也是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之后發(fā)現(xiàn),原來問題在os這里,ubatu的mysql通過yum安裝或者rpm安裝的時(shí)候,會(huì)建一個(gè)/etc/apparmor.d/usr.sbin.mysqld 文件,如果數(shù)據(jù)目錄不在這里面,則會(huì)報(bào)錯(cuò),

/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實(shí)例,ok,問題解決。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • MySql報(bào)錯(cuò)Table mysql.plugin doesn’t exist的解決方法
  • mysql自動(dòng)停止 Plugin FEDERATED is disabled 的完美解決方法
  • MySQL部署時(shí)提示Table mysql.plugin doesn’t exist的解決方法

標(biāo)簽:固原 溫州 內(nèi)江 撫順 浙江 防疫工作 廣西 汕尾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL中報(bào)錯(cuò):Can’t find file: ‘./mysql/plugin.frm’的解決方法》,本文關(guān)鍵詞  MySQL,中,報(bào)錯(cuò),Can,find,file,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL中報(bào)錯(cuò):Can’t find file: ‘./mysql/plugin.frm’的解決方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL中報(bào)錯(cuò):Can’t find file: ‘./mysql/plugin.frm’的解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章