基於linux使用mysql二進位包安裝mysql5.5

來源:互聯網
上載者:User
前言

使用mysql也有一段時間,但是安裝mysql,都是在linux上使用軟體源的安裝,再使用mysql內建的shell執行的便捷啟動,對於mysql內部的啟動參數不甚瞭解,所以特意從mysql官網下載mysql的tar包,自行安裝啟動,瞭解mysql程式的啟動過程,有助於啟動過程的排錯,進一步瞭解mysql。

環境

ubuntu 12.04 32bit

下載mysql

1.下載:在http://dev.mysql.com/downloads/mysql/官網上下載mysql-5.5.28-linux2.6-i686.tar.gz.

2.解壓

tar -xvf mysql-5.5.28-linux2.6-i686.tar.gz

3.移動到/usr/local/mysql

mv mysql-5.5.28-linux2.6-i686 /usr/local/ln -s mysql-5.5.28-linux2.6-i686/ mysql

4.安裝依賴的lib包:執行/usr/local/bin/mysql/bin/mysqld,報錯

/usr/local/mysql/bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

使用apt-cache search libaio,找到如下軟體源

libaio-dev - Linux kernel AIO access library - development fileslibaio1 - Linux kernel AIO access library - shared librarylibaio1-dbg - Linux kernel AIO access library - debugging symbols

使用apt-get install libaio1.

 

配置使用者,目錄
shell> groupadd mysqlshell> useradd -r -g mysql mysqlshell> cd /usr/local/mysqlshell> chown -R mysql .shell> chgrp -R mysql .

 

初始化mysql
shell> scripts/mysql_install_db --user=mysql
# Next command is optionalshell> cp support-files/my-medium.cnf /etc/my.cnf
# Next command is optionalshell> cp support-files/mysql.server /etc/init.d/mysql.server

 這裡最重要的就是初始化mysql的一些許可權賬戶表,預設建立了一個空密碼的root使用者

 

啟動mysql

最簡單的啟動方式:

shell> /usr/local/mysql/bin/mysqld --user=mysql

預設情況下使用/usr/local/mysql/data作為mysql的資料目錄,包括資料庫檔案,log日誌。

 

常用的mysql啟動參數:

/usr/local/mysql/bin/mysqld  --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  --port=3306 --socket=/tmp/mysql.sock

 

推薦的啟動mysql

/usr/local/mysql/support-files/mysql.server start

一般來說,沒什麼特別需要的話就是使用上述指令碼啟動mysql伺服器了,這個指令碼可以加入到linux的系統服務。

 

關閉mysql

最簡單的方式

killall mysqld

推薦的方式

/usr/local/mysql/support-files/mysql.server stop

使用mysql.server stop關閉mysqld會銷毀pid檔案,並做容錯操作,但是最後也是調用kill命令kill mysql。

關閉mysql,盡量不要用kill -9 mysql_pid或者是killall -9 mysql,否則mysql進程無法做退出處理,就可能會遺失資料,甚至導致表損壞。

 

 

淺析mysql.server指令碼的啟動流程

mysql.server指令碼可以看到在以下指令碼調用mysqld_safe這個bash

$bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null 2>&1 &

預設情況下,$bindir/mysqld_safe就是/usr/local/mysql/bin/mysqld_safe這個shell,我的原生調用參數如下:

/bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/blue-pc.pid

而mysqld_safe也是一個shell,可以看到在這個指令碼在初始化N多變數後,調用

eval_log_error "$cmd"

這個shell function最後就是調用

 #echo "Running mysqld: [$cmd]" eval "$cmd"

在我本機,這個$cmd就是

/usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/usr/local/mysql/data/blue-pc.err --pid-file=/usr/local/mysql/data/blue-pc.pid

 

參考 http://dev.mysql.com/doc/refman/5.5/en/binary-installation.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.