MySQL出现启动报错问题InnoDB:Unable to lock/ibdata1 error怎么办
这篇文章给大家分享的是有关MySQL出现启动报错问题InnoDB:Unable to lock/ibdata1 error怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
在OS X环境下MySQL启动时报错:
016-03-03T00:02:30.483037Z0[ERROR]InnoDB:Unabletolock./ibdata1error:352016-03-03T00:02:30.483100Z0[Note]InnoDB:CheckthatyoudonotalreadyhaveanothermysqldprocessusingthesameInnoDBdataorlogfiles.
终端不断地重复打印上面的错误日志,从错误日志看起来似乎有另外一个mysqld进程占用了./ibdata1文件,于是使用ps命令查看是否有mysqld进程在运行:
ps-ef|grepmysqld747711108: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
发现有一个7711的进程在运行,于是强制kill掉:
sudokill-97711
再次ps查询:
ps-ef|grepmysqld747759108: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
发现还在,只不过pid由原来的7711变成了现在的7759,那么看看mysqld进程打开了哪些文件:
lsof-cmysqld
该进程没有打开任何文件,这就见鬼了。
Mac OS X, lsof only shows your own processes unless running as root with sudo
于是再次运行:
sudolsof-cmysqldCOMMANDPIDUSERFDTYPEDEVICESIZE/OFFNODENAMEmysqld8655_mysqlcwdDIR1,45443090250/usr/local/mysql/datamysqld8655_mysqltxtREG1,4311307363089789/usr/local/mysql/bin/mysqld
的确发现有一个实实在在的mysqld进程在运行,也占用的这些mysql文件,经过一番Google大法,发现在OS X中启动MySQL跟在Linux中启动方式完全是牛马不相及,在OS X中启动/重启MySQL的正确姿势是:
sudolaunchctlunload-w/Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist
此时再来看看是否还有mysqld进程:
ps-ef|grepmysqld
嗯,发现确实没有了,再来启动MySQL:
sudolaunchctlload-w/Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist
问题总算解决,但还没完,总得把原理搞清楚才行。
LAUNCHD是什么?
launchd是Mac OS X从10.4开始引入,用于用于初始化系统环境的关键进程,它是内核装载成功之后在OS环境下启动的第一个进程。传统的Linux会使用/etc/rc.*或者/etc/init来管理开机要启动的服务,而在OS X中就是使用launchd来管理。采用这种方式来配置启动项很简单,只需要一个plist文件。/Library/LaunchDaemons目录下的plist文件都是系统启动后立即启动进程。使用launchctl命令加载/卸载plist文件,加载配置文件后,程序启动,卸载配置文件后程序关闭。
卸载配置文件后又尝试直接用mysqld命令来启动mysql进程试试:
/usr/local/mysql/bin/mysqld2016-03-03T01:35:50.359258Z0[ERROR]InnoDB:./ib_logfile0can'tbeopenedinread-writemode.2016-03-03T01:35:50.359283Z0[ERROR]InnoDB:PlugininitializationabortedwitherrorGenericerror2016-03-03T01:35:50.670517Z0[ERROR]Plugin'InnoDB'initfunctionreturnederror.2016-03-03T01:35:50.670555Z0[ERROR]Plugin'InnoDB'registrationasaSTORAGEENGINEfailed.2016-03-03T01:35:50.670568Z0[ERROR]Failedtoinitializeplugins.2016-03-03T01:35:50.670574Z0[ERROR]Aborting
ib_logfile0不能被打开,猜测是用户权限文件,不能用当前系统用户启动mysql。那么加上sudo看看,用root来启动:
2016-03-03T01:38:10.977313Z0[ERROR]Fatalerror:Pleaseread"Security"sectionofthemanualtofindouthowtorunmysqldasroot!2016-03-03T01:38:10.977339Z0[ERROR]Aborting2016-03-03T01:38:10.977350Z0[Note]Binlogend2016-03-03T01:38:10.977410Z0[Note]/usr/local/mysql/bin/mysqld:Shutdowncomplete
叫我去读MySQL的安全手册,还是用launchd的方式启动吧。
感谢各位的阅读!关于“MySQL出现启动报错问题InnoDB:Unable to lock/ibdata1 error怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。