亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL啟動報錯問題InnoDB:Unable to lock/ibdata1 error

 更新時間:2019年07月02日 08:32:04   作者:FOOFISH-PYTHON之禪  
這篇文章主要介紹了MySQL啟動報錯問題InnoDB:Unable to lock/ibdata1 error,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

在OS X環(huán)境下MySQL啟動時報錯:

016-03-03T00:02:30.483037Z 0 [ERROR] InnoDB: Unable to lock ./ibdata1 error: 35
2016-03-03T00:02:30.483100Z 0 [Note] InnoDB: Check that you do not already have another mysqld process using the same InnoDB data or log files.

終端不斷地重復(fù)打印上面的錯誤日志,從錯誤日志看起來似乎有另外一個mysqld進(jìn)程占用了./ibdata1文件,于是使用ps命令查看是否有mysqld進(jìn)程在運(yùn)行:

ps -ef |grep mysqld
74 7711 1 0 8:04上午 ?? 0:00.34 /usr/local/mysql/bin/mysqld --user=_mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --log-error=/usr/local/mysql/data/mysqld.local.err --pid-file=/usr/local/mysql/data/mysqld.local.pid

發(fā)現(xiàn)有一個7711的進(jìn)程在運(yùn)行,于是強(qiáng)制kill掉:

sudo kill -9 7711

再次ps查詢:

ps -ef |grep mysqld
74 7759 1 0 8:10上午 ?? 0:00.29 /usr/local/mysql/bin/mysqld --user=_mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --log-error=/usr/local/mysql/data/mysqld.local.err --pid-file=/usr/local/mysql/data/mysqld.local.pid

發(fā)現(xiàn)還在,只不過pid由原來的7711變成了現(xiàn)在的7759,那么看看mysqld進(jìn)程打開了哪些文件:

lsof -c mysqld

該進(jìn)程沒有打開任何文件,這就見鬼了。

Mac OS X, lsof only shows your own processes unless running as root with sudo

于是再次運(yùn)行:

sudo lsof -c mysqld
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mysqld 8655 _mysql cwd DIR 1,4 544 3090250 /usr/local/mysql/data
mysqld 8655 _mysql txt REG 1,4 31130736 3089789 /usr/local/mysql/bin/mysqld

的確發(fā)現(xiàn)有一個實(shí)實(shí)在在的mysqld進(jìn)程在運(yùn)行,也占用的這些mysql文件,經(jīng)過一番Google大法,發(fā)現(xiàn)在OS X中啟動MySQL跟在Linux中啟動方式完全是牛馬不相及,在OS X中啟動/重啟MySQL的正確姿勢是:

sudo launchctl unload -w /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist

此時再來看看是否還有mysqld進(jìn)程:

ps -ef |grep mysqld

嗯,發(fā)現(xiàn)確實(shí)沒有了,再來啟動MySQL:

sudo launchctl load -w /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist

問題總算解決,但還沒完,總得把原理搞清楚才行。

LAUNCHD是什么?

launchd是Mac OS X從10.4開始引入,用于用于初始化系統(tǒng)環(huán)境的關(guān)鍵進(jìn)程,它是內(nèi)核裝載成功之后在OS環(huán)境下啟動的第一個進(jìn)程。傳統(tǒng)的Linux會使用/etc/rc.*或者/etc/init來管理開機(jī)要啟動的服務(wù),而在OS X中就是使用launchd來管理。采用這種方式來配置啟動項(xiàng)很簡單,只需要一個plist文件。/Library/LaunchDaemons目錄下的plist文件都是系統(tǒng)啟動后立即啟動進(jìn)程。使用launchctl命令加載/卸載plist文件,加載配置文件后,程序啟動,卸載配置文件后程序關(guān)閉。

卸載配置文件后又嘗試直接用mysqld命令來啟動mysql進(jìn)程試試:

/usr/local/mysql/bin/mysqld
2016-03-03T01:35:50.359258Z 0 [ERROR] InnoDB: ./ib_logfile0 can't be opened in read-write mode.
2016-03-03T01:35:50.359283Z 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
2016-03-03T01:35:50.670517Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
2016-03-03T01:35:50.670555Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2016-03-03T01:35:50.670568Z 0 [ERROR] Failed to initialize plugins.
2016-03-03T01:35:50.670574Z 0 [ERROR] Aborting

ib_logfile0不能被打開,猜測是用戶權(quán)限文件,不能用當(dāng)前系統(tǒng)用戶啟動mysql。那么加上sudo看看,用root來啟動:

2016-03-03T01:38:10.977313Z 0 [ERROR] Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!
2016-03-03T01:38:10.977339Z 0 [ERROR] Aborting
2016-03-03T01:38:10.977350Z 0 [Note] Binlog end
2016-03-03T01:38:10.977410Z 0 [Note] /usr/local/mysql/bin/mysqld: Shutdown complete

叫我去讀MySQL的安全手冊,還是用launchd的方式啟動吧。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL數(shù)據(jù)庫表修復(fù) MyISAM

    MySQL數(shù)據(jù)庫表修復(fù) MyISAM

    這篇文章主要介紹了MySQL數(shù)據(jù)庫表修復(fù) MyISAM ,需要的朋友可以參考下
    2014-06-06
  • MySQL中LOW_PRIORITY含義和用法詳解

    MySQL中LOW_PRIORITY含義和用法詳解

    LOW_PRIORITY是MySQL中的一個關(guān)鍵字,它用于在執(zhí)行某些操作時改變這些操作的優(yōu)先級,本文主要介紹了MySQL中LOW_PRIORITY用法,感興趣的可以了解一下
    2024-07-07
  • mysql 5.7.21解壓版本安裝 Navicat數(shù)據(jù)庫操作工具安裝

    mysql 5.7.21解壓版本安裝 Navicat數(shù)據(jù)庫操作工具安裝

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.21解壓版本安裝,Navicat數(shù)據(jù)庫操作工具安裝,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • 安裝Mysql時可能會遇到的一些疑難雜癥

    安裝Mysql時可能會遇到的一些疑難雜癥

    這篇文章主要給大家介紹了關(guān)于安裝Mysql時可能會遇到的一些疑難雜癥,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • MySQL子查詢詳細(xì)教程

    MySQL子查詢詳細(xì)教程

    這篇文章主要介紹了MySQL子查詢詳細(xì)教程的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • MySQL監(jiān)控Innodb信息工作流程

    MySQL監(jiān)控Innodb信息工作流程

    這篇文章主要為大家介紹了MySQL監(jiān)控Innodb信息工作流程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-02-02
  • mysql根據(jù)拼音字母查詢(簡單易懂的字段拼音查詢)

    mysql根據(jù)拼音字母查詢(簡單易懂的字段拼音查詢)

    MySQL在開發(fā)中,我們經(jīng)常需要根據(jù)字段拼音查詢數(shù)據(jù)庫中的數(shù)據(jù),它支持多種查詢方式,包括根據(jù)拼音字母查詢,使用 Collation 可以方便地進(jìn)行簡單的拼音查詢,而使用拼音索引可以大幅提高查詢性能,根據(jù)具體的需求和情況,我們可以選擇合適的方法來實(shí)現(xiàn)拼音查詢
    2023-10-10
  • MySQL性能優(yōu)化之table_cache配置參數(shù)淺析

    MySQL性能優(yōu)化之table_cache配置參數(shù)淺析

    這篇文章主要介紹了MySQL性能優(yōu)化之table_cache配置參數(shù)淺析,本文介紹了它的緩存機(jī)制、參數(shù)優(yōu)化及清空緩存的命令等,需要的朋友可以參考下
    2014-07-07
  • MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法

    MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法

    這篇文章主要介紹了MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Mysql字符串截取函數(shù)SUBSTRING的用法說明

    Mysql字符串截取函數(shù)SUBSTRING的用法說明

    今天建視圖時,用到了MySQL中的字符串截取,很是方便。
    2011-06-06

最新評論