今天同事A找到我,說是Mysql server X的負(fù)載很高,查詢很慢。他自己搗鼓了一陣未果后,我們一起看了下。
| [root@redhat var]# uname -aLinux xxx 2.6.18-128.el5 #1 SMP Wed Dec 17 11:41:38 EST 2008 x86_64 x86_64 x86_64 GNU/Linux[root@redhat var]# mysql -u root -p -e “select version();”+------------+| version() |+------------+| 5.1.32-log |+------------+ |
同事A的操作:
A一看mysql server有問題第一反應(yīng)是重啟mysql server,囧!!o(╯□╰)
但是又使用了錯誤的命令
| [root@redhat var]# /var/lib/mysql/libexec/mysqld restart ----操作①100708 14:43:53 [ERROR] Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!100708 14:43:53 [ERROR] Aborting100708 14:43:53 [Note] /var/lib/mysql/libexec/mysqld: Shutdown complete |
發(fā)現(xiàn)問題后,他又想起來應(yīng)該是用下面的命令重啟
| [root@redhat var]# service mysql restart ----操作②MySQL manager or server PID file could not be found! [FAILED]Starting MySQL...... |
CTRL+C取消
這時候
| [root@redhat var]# ps aux | grep mysql |
可以看到,系統(tǒng)又啟動了一個Mysql進程,但是過一會后,會自動消失,這時候看日志可以發(fā)現(xiàn)以下錯誤:
| 100708 15:26:52 [ERROR] Can't start server: Bind on TCP/IP port: Address already in use100708 15:26:52 [ERROR] Do you already have another mysqld server running on port: 30017 ?100708 15:26:52 [ERROR] Aborting |
然后后面我們一起看。
首先我用client工具連接,發(fā)現(xiàn)mysql正常。web應(yīng)用連接數(shù)據(jù)庫也正常只是查詢很慢。
其次我在命令下面,連接:
| [root@redhat var]# mysql -u root -p |
提示:
| Enter password:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) |
這時候同事A提醒我,可以重啟服務(wù)沒關(guān)系。囧,o(╯□╰)o,他在建議我重啟解決問題。
好吧,如他所愿。于是我先:
| [root@redhat var]# service mysql stopMySQL is running but PID file could not be found |
然后去mysql data dir下面查看,果然沒有pid file。
這時候我的第一反應(yīng)是配置文件不對,導(dǎo)致不能正常停止和重啟。
由于server是好的,因此我沒有急著去比較以前備份的/etc/my.cnf.bak和/etc/my.cnf。
我們先查找負(fù)載高的原因。因為命令行下無法進入mysql,在client下使用
可以看到里面有很多l(xiāng)ocked的查詢,其中等待時間最久的一個是一個select查詢,顯示正在sending data,然后其余都是locked。
|
新聞熱點
疑難解答
圖片精選