mysql啓動過程

  1. 明白/etc/init.d/mysql從哪裏來,和mysql.server什麼關係?

  2. /etc/init.d/mysql和mysqld_safe之間的關係

  3. mysqld_safe怎麼把mysql啓動起來的


  1. mysql就是mysql.server拷貝到這裏來的。

  2. mysql啓動,調用mysqld_safe

  3. mysqld_safe調用mysqld將mysql啓動起來。


    擴展知識:mysqld_safe是mysqld的一個看門狗進程

    ps -axu | grep mysql找到mysql的pid

    kill -9 pid

    ps -axu | grep mysql發現又生成了一個mysql的進程。可以參考mysqld_safe的這一特點,自動啓動那些掛掉的應用。



    mysql啓動過程:mysql.server調用mysqld_safe,mysqld_safe調用mysqld進程。一般mysql啓動出現故障,我們需要去error.log查看error即可。但是有的時候mysql啓動報錯,但是確沒有寫進日誌,那麼怎麼辦呢?


    首先vim /etc/init.d/mysql,加入set -x。

    /etc/init.d/mysql start >> start.log 2>&1。可查看mysql啓動shell--start.log。


    啓用my.cnf參數malloc-lib=/usr/local/mysql/lib/mysql/libjemalloc.so,發現mysql起不來了。而且error.log日誌也沒有報錯信息。心慌了,怎麼辦。

    vim /etc/init.d/mysql中腳本, $bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null 2>&1 & 把下劃線部分去掉,讓啓動日誌重定向到終端。這時候再啓動就會有報錯信息了,Starting MySQL..150514 06:08:59 mysqld_safe --malloc-lib '/usr/local/mysql/lib/mysql/libjemalloc.so' can not be read and will not be used

那根據報錯信息,修改my.cnf文件,mysql就可以正常啓動了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章