于是再次運行:
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)有一個實實在在的mysqld進(jì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)確實沒有了,再來啟動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來管理。采用這種方式來配置啟動項很簡單,只需要一個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的方式啟動吧。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com